2 * vvvvvvvvvvvvvvvvvvvvvvv Original vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
3 * Copyright (C) 1992 Eric Youngdale
4 * Simulate a host adapter with 2 disks attached. Do a lot of checking
5 * to make sure that we are not getting blocks mixed up, and PANIC if
6 * anything out of the ordinary is seen.
7 * ^^^^^^^^^^^^^^^^^^^^^^^ Original ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
9 * This version is more generic, simulating a variable number of disk
10 * (or disk like devices) sharing a common amount of RAM. To be more
11 * realistic, the simulated devices have the transport attributes of
15 * For documentation see http://www.torque.net/sg/sdebug26.html
17 * D. Gilbert (dpg) work for Magneto-Optical device test [20010421]
18 * dpg: work for devfs large number of disks [20010809]
19 * forked for lk 2.5 series [20011216, 20020101]
20 * use vmalloc() more inquiry+mode_sense [20020302]
21 * add timers for delayed responses [20020721]
22 * Patrick Mansfield <patmans@us.ibm.com> max_luns+scsi_level [20021031]
23 * Mike Anderson <andmike@us.ibm.com> sysfs work [20021118]
24 * dpg: change style of boot options to "scsi_debug.num_tgts=2" and
25 * module options to "modprobe scsi_debug num_tgts=2" [20021221]
28 #include <linux/module.h>
30 #include <linux/kernel.h>
31 #include <linux/errno.h>
32 #include <linux/timer.h>
33 #include <linux/types.h>
34 #include <linux/string.h>
35 #include <linux/genhd.h>
37 #include <linux/init.h>
38 #include <linux/proc_fs.h>
39 #include <linux/vmalloc.h>
40 #include <linux/moduleparam.h>
41 #include <linux/scatterlist.h>
42 #include <linux/blkdev.h>
44 #include <scsi/scsi.h>
45 #include <scsi/scsi_cmnd.h>
46 #include <scsi/scsi_device.h>
47 #include <scsi/scsi_host.h>
48 #include <scsi/scsicam.h>
49 #include <scsi/scsi_eh.h>
51 #include <linux/stat.h>
53 #include "scsi_logging.h"
55 #define SCSI_DEBUG_VERSION "1.81"
56 static const char * scsi_debug_version_date
= "20070104";
58 /* Additional Sense Code (ASC) */
59 #define NO_ADDITIONAL_SENSE 0x0
60 #define LOGICAL_UNIT_NOT_READY 0x4
61 #define UNRECOVERED_READ_ERR 0x11
62 #define PARAMETER_LIST_LENGTH_ERR 0x1a
63 #define INVALID_OPCODE 0x20
64 #define ADDR_OUT_OF_RANGE 0x21
65 #define INVALID_FIELD_IN_CDB 0x24
66 #define INVALID_FIELD_IN_PARAM_LIST 0x26
67 #define POWERON_RESET 0x29
68 #define SAVING_PARAMS_UNSUP 0x39
69 #define TRANSPORT_PROBLEM 0x4b
70 #define THRESHOLD_EXCEEDED 0x5d
71 #define LOW_POWER_COND_ON 0x5e
73 /* Additional Sense Code Qualifier (ASCQ) */
74 #define ACK_NAK_TO 0x3
76 #define SDEBUG_TAGGED_QUEUING 0 /* 0 | MSG_SIMPLE_TAG | MSG_ORDERED_TAG */
78 /* Default values for driver parameters */
79 #define DEF_NUM_HOST 1
80 #define DEF_NUM_TGTS 1
81 #define DEF_MAX_LUNS 1
82 /* With these defaults, this driver will make 1 host with 1 target
83 * (id 0) containing 1 logical unit (lun 0). That is 1 device.
86 #define DEF_DEV_SIZE_MB 8
87 #define DEF_EVERY_NTH 0
88 #define DEF_NUM_PARTS 0
90 #define DEF_SCSI_LEVEL 5 /* INQUIRY, byte2 [5->SPC-3] */
93 #define DEF_NO_LUN_0 0
94 #define DEF_VIRTUAL_GB 0
96 #define DEF_VPD_USE_HOSTNO 1
97 #define DEF_SECTOR_SIZE 512
99 /* bit mask values for scsi_debug_opts */
100 #define SCSI_DEBUG_OPT_NOISE 1
101 #define SCSI_DEBUG_OPT_MEDIUM_ERR 2
102 #define SCSI_DEBUG_OPT_TIMEOUT 4
103 #define SCSI_DEBUG_OPT_RECOVERED_ERR 8
104 #define SCSI_DEBUG_OPT_TRANSPORT_ERR 16
105 /* When "every_nth" > 0 then modulo "every_nth" commands:
106 * - a no response is simulated if SCSI_DEBUG_OPT_TIMEOUT is set
107 * - a RECOVERED_ERROR is simulated on successful read and write
108 * commands if SCSI_DEBUG_OPT_RECOVERED_ERR is set.
109 * - a TRANSPORT_ERROR is simulated on successful read and write
110 * commands if SCSI_DEBUG_OPT_TRANSPORT_ERR is set.
112 * When "every_nth" < 0 then after "- every_nth" commands:
113 * - a no response is simulated if SCSI_DEBUG_OPT_TIMEOUT is set
114 * - a RECOVERED_ERROR is simulated on successful read and write
115 * commands if SCSI_DEBUG_OPT_RECOVERED_ERR is set.
116 * - a TRANSPORT_ERROR is simulated on successful read and write
117 * commands if SCSI_DEBUG_OPT_TRANSPORT_ERR is set.
118 * This will continue until some other action occurs (e.g. the user
119 * writing a new value (other than -1 or 1) to every_nth via sysfs).
122 /* when 1==SCSI_DEBUG_OPT_MEDIUM_ERR, a medium error is simulated at this
123 * sector on read commands: */
124 #define OPT_MEDIUM_ERR_ADDR 0x1234 /* that's sector 4660 in decimal */
126 /* If REPORT LUNS has luns >= 256 it can choose "flat space" (value 1)
127 * or "peripheral device" addressing (value 0) */
128 #define SAM2_LUN_ADDRESS_METHOD 0
129 #define SAM2_WLUN_REPORT_LUNS 0xc101
131 static int scsi_debug_add_host
= DEF_NUM_HOST
;
132 static int scsi_debug_delay
= DEF_DELAY
;
133 static int scsi_debug_dev_size_mb
= DEF_DEV_SIZE_MB
;
134 static int scsi_debug_every_nth
= DEF_EVERY_NTH
;
135 static int scsi_debug_max_luns
= DEF_MAX_LUNS
;
136 static int scsi_debug_num_parts
= DEF_NUM_PARTS
;
137 static int scsi_debug_num_tgts
= DEF_NUM_TGTS
; /* targets per host */
138 static int scsi_debug_opts
= DEF_OPTS
;
139 static int scsi_debug_scsi_level
= DEF_SCSI_LEVEL
;
140 static int scsi_debug_ptype
= DEF_PTYPE
; /* SCSI peripheral type (0==disk) */
141 static int scsi_debug_dsense
= DEF_D_SENSE
;
142 static int scsi_debug_no_lun_0
= DEF_NO_LUN_0
;
143 static int scsi_debug_virtual_gb
= DEF_VIRTUAL_GB
;
144 static int scsi_debug_fake_rw
= DEF_FAKE_RW
;
145 static int scsi_debug_vpd_use_hostno
= DEF_VPD_USE_HOSTNO
;
146 static int scsi_debug_sector_size
= DEF_SECTOR_SIZE
;
148 static int scsi_debug_cmnd_count
= 0;
150 #define DEV_READONLY(TGT) (0)
151 #define DEV_REMOVEABLE(TGT) (0)
153 static unsigned int sdebug_store_sectors
;
154 static sector_t sdebug_capacity
; /* in sectors */
156 /* old BIOS stuff, kernel may get rid of them but some mode sense pages
157 may still need them */
158 static int sdebug_heads
; /* heads per disk */
159 static int sdebug_cylinders_per
; /* cylinders per surface */
160 static int sdebug_sectors_per
; /* sectors per cylinder */
162 #define SDEBUG_MAX_PARTS 4
164 #define SDEBUG_SENSE_LEN 32
166 #define SCSI_DEBUG_CANQUEUE 255
167 #define SCSI_DEBUG_MAX_CMD_LEN 16
169 struct sdebug_dev_info
{
170 struct list_head dev_list
;
171 unsigned char sense_buff
[SDEBUG_SENSE_LEN
]; /* weak nexus */
172 unsigned int channel
;
175 struct sdebug_host_info
*sdbg_host
;
182 struct sdebug_host_info
{
183 struct list_head host_list
;
184 struct Scsi_Host
*shost
;
186 struct list_head dev_info_list
;
189 #define to_sdebug_host(d) \
190 container_of(d, struct sdebug_host_info, dev)
192 static LIST_HEAD(sdebug_host_list
);
193 static DEFINE_SPINLOCK(sdebug_host_list_lock
);
195 typedef void (* done_funct_t
) (struct scsi_cmnd
*);
197 struct sdebug_queued_cmd
{
199 struct timer_list cmnd_timer
;
200 done_funct_t done_funct
;
201 struct scsi_cmnd
* a_cmnd
;
204 static struct sdebug_queued_cmd queued_arr
[SCSI_DEBUG_CANQUEUE
];
206 static unsigned char * fake_storep
; /* ramdisk storage */
208 static int num_aborts
= 0;
209 static int num_dev_resets
= 0;
210 static int num_bus_resets
= 0;
211 static int num_host_resets
= 0;
213 static DEFINE_SPINLOCK(queued_arr_lock
);
214 static DEFINE_RWLOCK(atomic_rw
);
216 static char sdebug_proc_name
[] = "scsi_debug";
218 static struct bus_type pseudo_lld_bus
;
220 static struct device_driver sdebug_driverfs_driver
= {
221 .name
= sdebug_proc_name
,
222 .bus
= &pseudo_lld_bus
,
225 static const int check_condition_result
=
226 (DRIVER_SENSE
<< 24) | SAM_STAT_CHECK_CONDITION
;
228 static unsigned char ctrl_m_pg
[] = {0xa, 10, 2, 0, 0, 0, 0, 0,
230 static unsigned char iec_m_pg
[] = {0x1c, 0xa, 0x08, 0, 0, 0, 0, 0,
233 static int sdebug_add_adapter(void);
234 static void sdebug_remove_adapter(void);
236 static void sdebug_max_tgts_luns(void)
238 struct sdebug_host_info
*sdbg_host
;
239 struct Scsi_Host
*hpnt
;
241 spin_lock(&sdebug_host_list_lock
);
242 list_for_each_entry(sdbg_host
, &sdebug_host_list
, host_list
) {
243 hpnt
= sdbg_host
->shost
;
244 if ((hpnt
->this_id
>= 0) &&
245 (scsi_debug_num_tgts
> hpnt
->this_id
))
246 hpnt
->max_id
= scsi_debug_num_tgts
+ 1;
248 hpnt
->max_id
= scsi_debug_num_tgts
;
249 /* scsi_debug_max_luns; */
250 hpnt
->max_lun
= SAM2_WLUN_REPORT_LUNS
;
252 spin_unlock(&sdebug_host_list_lock
);
255 static void mk_sense_buffer(struct sdebug_dev_info
*devip
, int key
,
258 unsigned char *sbuff
;
260 sbuff
= devip
->sense_buff
;
261 memset(sbuff
, 0, SDEBUG_SENSE_LEN
);
263 scsi_build_sense_buffer(scsi_debug_dsense
, sbuff
, key
, asc
, asq
);
265 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
266 printk(KERN_INFO
"scsi_debug: [sense_key,asc,ascq]: "
267 "[0x%x,0x%x,0x%x]\n", key
, asc
, asq
);
270 static void get_data_transfer_info(unsigned char *cmd
,
271 unsigned long long *lba
, unsigned int *num
)
276 *lba
= (u64
)cmd
[9] | (u64
)cmd
[8] << 8 |
277 (u64
)cmd
[7] << 16 | (u64
)cmd
[6] << 24 |
278 (u64
)cmd
[5] << 32 | (u64
)cmd
[4] << 40 |
279 (u64
)cmd
[3] << 48 | (u64
)cmd
[2] << 56;
281 *num
= (u32
)cmd
[13] | (u32
)cmd
[12] << 8 | (u32
)cmd
[11] << 16 |
286 *lba
= (u32
)cmd
[5] | (u32
)cmd
[4] << 8 | (u32
)cmd
[3] << 16 |
289 *num
= (u32
)cmd
[9] | (u32
)cmd
[8] << 8 | (u32
)cmd
[7] << 16 |
295 *lba
= (u32
)cmd
[5] | (u32
)cmd
[4] << 8 | (u32
)cmd
[3] << 16 |
298 *num
= (u32
)cmd
[8] | (u32
)cmd
[7] << 8;
302 *lba
= (u32
)cmd
[3] | (u32
)cmd
[2] << 8 |
303 (u32
)(cmd
[1] & 0x1f) << 16;
304 *num
= (0 == cmd
[4]) ? 256 : cmd
[4];
311 static int scsi_debug_ioctl(struct scsi_device
*dev
, int cmd
, void __user
*arg
)
313 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
) {
314 printk(KERN_INFO
"scsi_debug: ioctl: cmd=0x%x\n", cmd
);
317 /* return -ENOTTY; // correct return but upsets fdisk */
320 static int check_readiness(struct scsi_cmnd
* SCpnt
, int reset_only
,
321 struct sdebug_dev_info
* devip
)
324 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
325 printk(KERN_INFO
"scsi_debug: Reporting Unit "
326 "attention: power on reset\n");
328 mk_sense_buffer(devip
, UNIT_ATTENTION
, POWERON_RESET
, 0);
329 return check_condition_result
;
331 if ((0 == reset_only
) && devip
->stopped
) {
332 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
333 printk(KERN_INFO
"scsi_debug: Reporting Not "
334 "ready: initializing command required\n");
335 mk_sense_buffer(devip
, NOT_READY
, LOGICAL_UNIT_NOT_READY
,
337 return check_condition_result
;
342 /* Returns 0 if ok else (DID_ERROR << 16). Sets scp->resid . */
343 static int fill_from_dev_buffer(struct scsi_cmnd
*scp
, unsigned char *arr
,
347 struct scsi_data_buffer
*sdb
= scsi_in(scp
);
351 if (!(scsi_bidi_cmnd(scp
) || scp
->sc_data_direction
== DMA_FROM_DEVICE
))
352 return (DID_ERROR
<< 16);
354 act_len
= sg_copy_from_buffer(sdb
->table
.sgl
, sdb
->table
.nents
,
357 sdb
->resid
-= act_len
;
359 sdb
->resid
= scsi_bufflen(scp
) - act_len
;
364 /* Returns number of bytes fetched into 'arr' or -1 if error. */
365 static int fetch_to_dev_buffer(struct scsi_cmnd
*scp
, unsigned char *arr
,
368 if (!scsi_bufflen(scp
))
370 if (!(scsi_bidi_cmnd(scp
) || scp
->sc_data_direction
== DMA_TO_DEVICE
))
373 return scsi_sg_copy_to_buffer(scp
, arr
, arr_len
);
377 static const char * inq_vendor_id
= "Linux ";
378 static const char * inq_product_id
= "scsi_debug ";
379 static const char * inq_product_rev
= "0004";
381 static int inquiry_evpd_83(unsigned char * arr
, int port_group_id
,
382 int target_dev_id
, int dev_id_num
,
383 const char * dev_id_str
,
389 port_a
= target_dev_id
+ 1;
390 /* T10 vendor identifier field format (faked) */
391 arr
[0] = 0x2; /* ASCII */
394 memcpy(&arr
[4], inq_vendor_id
, 8);
395 memcpy(&arr
[12], inq_product_id
, 16);
396 memcpy(&arr
[28], dev_id_str
, dev_id_str_len
);
397 num
= 8 + 16 + dev_id_str_len
;
400 if (dev_id_num
>= 0) {
401 /* NAA-5, Logical unit identifier (binary) */
402 arr
[num
++] = 0x1; /* binary (not necessarily sas) */
403 arr
[num
++] = 0x3; /* PIV=0, lu, naa */
406 arr
[num
++] = 0x53; /* naa-5 ieee company id=0x333333 (fake) */
410 arr
[num
++] = (dev_id_num
>> 24);
411 arr
[num
++] = (dev_id_num
>> 16) & 0xff;
412 arr
[num
++] = (dev_id_num
>> 8) & 0xff;
413 arr
[num
++] = dev_id_num
& 0xff;
414 /* Target relative port number */
415 arr
[num
++] = 0x61; /* proto=sas, binary */
416 arr
[num
++] = 0x94; /* PIV=1, target port, rel port */
417 arr
[num
++] = 0x0; /* reserved */
418 arr
[num
++] = 0x4; /* length */
419 arr
[num
++] = 0x0; /* reserved */
420 arr
[num
++] = 0x0; /* reserved */
422 arr
[num
++] = 0x1; /* relative port A */
424 /* NAA-5, Target port identifier */
425 arr
[num
++] = 0x61; /* proto=sas, binary */
426 arr
[num
++] = 0x93; /* piv=1, target port, naa */
429 arr
[num
++] = 0x52; /* naa-5, company id=0x222222 (fake) */
433 arr
[num
++] = (port_a
>> 24);
434 arr
[num
++] = (port_a
>> 16) & 0xff;
435 arr
[num
++] = (port_a
>> 8) & 0xff;
436 arr
[num
++] = port_a
& 0xff;
437 /* NAA-5, Target port group identifier */
438 arr
[num
++] = 0x61; /* proto=sas, binary */
439 arr
[num
++] = 0x95; /* piv=1, target port group id */
444 arr
[num
++] = (port_group_id
>> 8) & 0xff;
445 arr
[num
++] = port_group_id
& 0xff;
446 /* NAA-5, Target device identifier */
447 arr
[num
++] = 0x61; /* proto=sas, binary */
448 arr
[num
++] = 0xa3; /* piv=1, target device, naa */
451 arr
[num
++] = 0x52; /* naa-5, company id=0x222222 (fake) */
455 arr
[num
++] = (target_dev_id
>> 24);
456 arr
[num
++] = (target_dev_id
>> 16) & 0xff;
457 arr
[num
++] = (target_dev_id
>> 8) & 0xff;
458 arr
[num
++] = target_dev_id
& 0xff;
459 /* SCSI name string: Target device identifier */
460 arr
[num
++] = 0x63; /* proto=sas, UTF-8 */
461 arr
[num
++] = 0xa8; /* piv=1, target device, SCSI name string */
464 memcpy(arr
+ num
, "naa.52222220", 12);
466 snprintf(b
, sizeof(b
), "%08X", target_dev_id
);
467 memcpy(arr
+ num
, b
, 8);
469 memset(arr
+ num
, 0, 4);
475 static unsigned char vpd84_data
[] = {
476 /* from 4th byte */ 0x22,0x22,0x22,0x0,0xbb,0x0,
477 0x22,0x22,0x22,0x0,0xbb,0x1,
478 0x22,0x22,0x22,0x0,0xbb,0x2,
481 static int inquiry_evpd_84(unsigned char * arr
)
483 memcpy(arr
, vpd84_data
, sizeof(vpd84_data
));
484 return sizeof(vpd84_data
);
487 static int inquiry_evpd_85(unsigned char * arr
)
490 const char * na1
= "https://www.kernel.org/config";
491 const char * na2
= "http://www.kernel.org/log";
494 arr
[num
++] = 0x1; /* lu, storage config */
495 arr
[num
++] = 0x0; /* reserved */
500 plen
= ((plen
/ 4) + 1) * 4;
501 arr
[num
++] = plen
; /* length, null termianted, padded */
502 memcpy(arr
+ num
, na1
, olen
);
503 memset(arr
+ num
+ olen
, 0, plen
- olen
);
506 arr
[num
++] = 0x4; /* lu, logging */
507 arr
[num
++] = 0x0; /* reserved */
512 plen
= ((plen
/ 4) + 1) * 4;
513 arr
[num
++] = plen
; /* length, null terminated, padded */
514 memcpy(arr
+ num
, na2
, olen
);
515 memset(arr
+ num
+ olen
, 0, plen
- olen
);
521 /* SCSI ports VPD page */
522 static int inquiry_evpd_88(unsigned char * arr
, int target_dev_id
)
527 port_a
= target_dev_id
+ 1;
529 arr
[num
++] = 0x0; /* reserved */
530 arr
[num
++] = 0x0; /* reserved */
532 arr
[num
++] = 0x1; /* relative port 1 (primary) */
533 memset(arr
+ num
, 0, 6);
536 arr
[num
++] = 12; /* length tp descriptor */
537 /* naa-5 target port identifier (A) */
538 arr
[num
++] = 0x61; /* proto=sas, binary */
539 arr
[num
++] = 0x93; /* PIV=1, target port, NAA */
540 arr
[num
++] = 0x0; /* reserved */
541 arr
[num
++] = 0x8; /* length */
542 arr
[num
++] = 0x52; /* NAA-5, company_id=0x222222 (fake) */
546 arr
[num
++] = (port_a
>> 24);
547 arr
[num
++] = (port_a
>> 16) & 0xff;
548 arr
[num
++] = (port_a
>> 8) & 0xff;
549 arr
[num
++] = port_a
& 0xff;
551 arr
[num
++] = 0x0; /* reserved */
552 arr
[num
++] = 0x0; /* reserved */
554 arr
[num
++] = 0x2; /* relative port 2 (secondary) */
555 memset(arr
+ num
, 0, 6);
558 arr
[num
++] = 12; /* length tp descriptor */
559 /* naa-5 target port identifier (B) */
560 arr
[num
++] = 0x61; /* proto=sas, binary */
561 arr
[num
++] = 0x93; /* PIV=1, target port, NAA */
562 arr
[num
++] = 0x0; /* reserved */
563 arr
[num
++] = 0x8; /* length */
564 arr
[num
++] = 0x52; /* NAA-5, company_id=0x222222 (fake) */
568 arr
[num
++] = (port_b
>> 24);
569 arr
[num
++] = (port_b
>> 16) & 0xff;
570 arr
[num
++] = (port_b
>> 8) & 0xff;
571 arr
[num
++] = port_b
& 0xff;
577 static unsigned char vpd89_data
[] = {
578 /* from 4th byte */ 0,0,0,0,
579 'l','i','n','u','x',' ',' ',' ',
580 'S','A','T',' ','s','c','s','i','_','d','e','b','u','g',' ',' ',
582 0x34,0,0,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
584 0x5a,0xc,0xff,0x3f,0x37,0xc8,0x10,0,0,0,0,0,0x3f,0,0,0,
585 0,0,0,0,0x58,0x58,0x58,0x58,0x58,0x58,0x58,0x58,0x20,0x20,0x20,0x20,
586 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0,0,0,0x40,0x4,0,0x2e,0x33,
587 0x38,0x31,0x20,0x20,0x20,0x20,0x54,0x53,0x38,0x33,0x30,0x30,0x33,0x31,
589 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,
591 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,
593 0,0,0,0x2f,0,0,0,0x2,0,0x2,0x7,0,0xff,0xff,0x1,0,
594 0x3f,0,0xc1,0xff,0x3e,0,0x10,0x1,0xb0,0xf8,0x50,0x9,0,0,0x7,0,
595 0x3,0,0x78,0,0x78,0,0xf0,0,0x78,0,0,0,0,0,0,0,
596 0,0,0,0,0,0,0,0,0x2,0,0,0,0,0,0,0,
597 0x7e,0,0x1b,0,0x6b,0x34,0x1,0x7d,0x3,0x40,0x69,0x34,0x1,0x3c,0x3,0x40,
598 0x7f,0x40,0,0,0,0,0xfe,0xfe,0,0,0,0,0,0xfe,0,0,
599 0,0,0,0,0,0,0,0,0xb0,0xf8,0x50,0x9,0,0,0,0,
600 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
601 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
602 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
603 0x1,0,0xb0,0xf8,0x50,0x9,0xb0,0xf8,0x50,0x9,0x20,0x20,0x2,0,0xb6,0x42,
604 0,0x80,0x8a,0,0x6,0x3c,0xa,0x3c,0xff,0xff,0xc6,0x7,0,0x1,0,0x8,
605 0xf0,0xf,0,0x10,0x2,0,0x30,0,0,0,0,0,0,0,0x6,0xfe,
606 0,0,0x2,0,0x50,0,0x8a,0,0x4f,0x95,0,0,0x21,0,0xb,0,
607 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
608 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
609 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
610 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
611 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
612 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
613 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
614 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
615 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
616 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
617 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
618 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0xa5,0x51,
621 static int inquiry_evpd_89(unsigned char * arr
)
623 memcpy(arr
, vpd89_data
, sizeof(vpd89_data
));
624 return sizeof(vpd89_data
);
628 static unsigned char vpdb0_data
[] = {
629 /* from 4th byte */ 0,0,0,4,
634 static int inquiry_evpd_b0(unsigned char * arr
)
636 memcpy(arr
, vpdb0_data
, sizeof(vpdb0_data
));
637 if (sdebug_store_sectors
> 0x400) {
638 arr
[4] = (sdebug_store_sectors
>> 24) & 0xff;
639 arr
[5] = (sdebug_store_sectors
>> 16) & 0xff;
640 arr
[6] = (sdebug_store_sectors
>> 8) & 0xff;
641 arr
[7] = sdebug_store_sectors
& 0xff;
643 return sizeof(vpdb0_data
);
646 static int inquiry_evpd_b1(unsigned char *arr
)
648 memset(arr
, 0, 0x3c);
655 #define SDEBUG_LONG_INQ_SZ 96
656 #define SDEBUG_MAX_INQ_ARR_SZ 584
658 static int resp_inquiry(struct scsi_cmnd
* scp
, int target
,
659 struct sdebug_dev_info
* devip
)
661 unsigned char pq_pdt
;
663 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
664 int alloc_len
, n
, ret
;
666 alloc_len
= (cmd
[3] << 8) + cmd
[4];
667 arr
= kzalloc(SDEBUG_MAX_INQ_ARR_SZ
, GFP_ATOMIC
);
669 return DID_REQUEUE
<< 16;
671 pq_pdt
= 0x1e; /* present, wlun */
672 else if (scsi_debug_no_lun_0
&& (0 == devip
->lun
))
673 pq_pdt
= 0x7f; /* not present, no device type */
675 pq_pdt
= (scsi_debug_ptype
& 0x1f);
677 if (0x2 & cmd
[1]) { /* CMDDT bit set */
678 mk_sense_buffer(devip
, ILLEGAL_REQUEST
, INVALID_FIELD_IN_CDB
,
681 return check_condition_result
;
682 } else if (0x1 & cmd
[1]) { /* EVPD bit set */
683 int lu_id_num
, port_group_id
, target_dev_id
, len
;
685 int host_no
= devip
->sdbg_host
->shost
->host_no
;
687 port_group_id
= (((host_no
+ 1) & 0x7f) << 8) +
688 (devip
->channel
& 0x7f);
689 if (0 == scsi_debug_vpd_use_hostno
)
691 lu_id_num
= devip
->wlun
? -1 : (((host_no
+ 1) * 2000) +
692 (devip
->target
* 1000) + devip
->lun
);
693 target_dev_id
= ((host_no
+ 1) * 2000) +
694 (devip
->target
* 1000) - 3;
695 len
= scnprintf(lu_id_str
, 6, "%d", lu_id_num
);
696 if (0 == cmd
[2]) { /* supported vital product data pages */
697 arr
[1] = cmd
[2]; /*sanity */
699 arr
[n
++] = 0x0; /* this page */
700 arr
[n
++] = 0x80; /* unit serial number */
701 arr
[n
++] = 0x83; /* device identification */
702 arr
[n
++] = 0x84; /* software interface ident. */
703 arr
[n
++] = 0x85; /* management network addresses */
704 arr
[n
++] = 0x86; /* extended inquiry */
705 arr
[n
++] = 0x87; /* mode page policy */
706 arr
[n
++] = 0x88; /* SCSI ports */
707 arr
[n
++] = 0x89; /* ATA information */
708 arr
[n
++] = 0xb0; /* Block limits (SBC) */
709 arr
[n
++] = 0xb1; /* Block characteristics (SBC) */
710 arr
[3] = n
- 4; /* number of supported VPD pages */
711 } else if (0x80 == cmd
[2]) { /* unit serial number */
712 arr
[1] = cmd
[2]; /*sanity */
714 memcpy(&arr
[4], lu_id_str
, len
);
715 } else if (0x83 == cmd
[2]) { /* device identification */
716 arr
[1] = cmd
[2]; /*sanity */
717 arr
[3] = inquiry_evpd_83(&arr
[4], port_group_id
,
718 target_dev_id
, lu_id_num
,
720 } else if (0x84 == cmd
[2]) { /* Software interface ident. */
721 arr
[1] = cmd
[2]; /*sanity */
722 arr
[3] = inquiry_evpd_84(&arr
[4]);
723 } else if (0x85 == cmd
[2]) { /* Management network addresses */
724 arr
[1] = cmd
[2]; /*sanity */
725 arr
[3] = inquiry_evpd_85(&arr
[4]);
726 } else if (0x86 == cmd
[2]) { /* extended inquiry */
727 arr
[1] = cmd
[2]; /*sanity */
728 arr
[3] = 0x3c; /* number of following entries */
729 arr
[4] = 0x0; /* no protection stuff */
730 arr
[5] = 0x7; /* head of q, ordered + simple q's */
731 } else if (0x87 == cmd
[2]) { /* mode page policy */
732 arr
[1] = cmd
[2]; /*sanity */
733 arr
[3] = 0x8; /* number of following entries */
734 arr
[4] = 0x2; /* disconnect-reconnect mp */
735 arr
[6] = 0x80; /* mlus, shared */
736 arr
[8] = 0x18; /* protocol specific lu */
737 arr
[10] = 0x82; /* mlus, per initiator port */
738 } else if (0x88 == cmd
[2]) { /* SCSI Ports */
739 arr
[1] = cmd
[2]; /*sanity */
740 arr
[3] = inquiry_evpd_88(&arr
[4], target_dev_id
);
741 } else if (0x89 == cmd
[2]) { /* ATA information */
742 arr
[1] = cmd
[2]; /*sanity */
743 n
= inquiry_evpd_89(&arr
[4]);
746 } else if (0xb0 == cmd
[2]) { /* Block limits (SBC) */
747 arr
[1] = cmd
[2]; /*sanity */
748 arr
[3] = inquiry_evpd_b0(&arr
[4]);
749 } else if (0xb1 == cmd
[2]) { /* Block characteristics (SBC) */
750 arr
[1] = cmd
[2]; /*sanity */
751 arr
[3] = inquiry_evpd_b1(&arr
[4]);
753 /* Illegal request, invalid field in cdb */
754 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
755 INVALID_FIELD_IN_CDB
, 0);
757 return check_condition_result
;
759 len
= min(((arr
[2] << 8) + arr
[3]) + 4, alloc_len
);
760 ret
= fill_from_dev_buffer(scp
, arr
,
761 min(len
, SDEBUG_MAX_INQ_ARR_SZ
));
765 /* drops through here for a standard inquiry */
766 arr
[1] = DEV_REMOVEABLE(target
) ? 0x80 : 0; /* Removable disk */
767 arr
[2] = scsi_debug_scsi_level
;
768 arr
[3] = 2; /* response_data_format==2 */
769 arr
[4] = SDEBUG_LONG_INQ_SZ
- 5;
770 if (0 == scsi_debug_vpd_use_hostno
)
771 arr
[5] = 0x10; /* claim: implicit TGPS */
772 arr
[6] = 0x10; /* claim: MultiP */
773 /* arr[6] |= 0x40; ... claim: EncServ (enclosure services) */
774 arr
[7] = 0xa; /* claim: LINKED + CMDQUE */
775 memcpy(&arr
[8], inq_vendor_id
, 8);
776 memcpy(&arr
[16], inq_product_id
, 16);
777 memcpy(&arr
[32], inq_product_rev
, 4);
778 /* version descriptors (2 bytes each) follow */
779 arr
[58] = 0x0; arr
[59] = 0x77; /* SAM-3 ANSI */
780 arr
[60] = 0x3; arr
[61] = 0x14; /* SPC-3 ANSI */
782 if (scsi_debug_ptype
== 0) {
783 arr
[n
++] = 0x3; arr
[n
++] = 0x3d; /* SBC-2 ANSI */
784 } else if (scsi_debug_ptype
== 1) {
785 arr
[n
++] = 0x3; arr
[n
++] = 0x60; /* SSC-2 no version */
787 arr
[n
++] = 0xc; arr
[n
++] = 0xf; /* SAS-1.1 rev 10 */
788 ret
= fill_from_dev_buffer(scp
, arr
,
789 min(alloc_len
, SDEBUG_LONG_INQ_SZ
));
794 static int resp_requests(struct scsi_cmnd
* scp
,
795 struct sdebug_dev_info
* devip
)
797 unsigned char * sbuff
;
798 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
799 unsigned char arr
[SDEBUG_SENSE_LEN
];
803 memset(arr
, 0, sizeof(arr
));
804 if (devip
->reset
== 1)
805 mk_sense_buffer(devip
, 0, NO_ADDITIONAL_SENSE
, 0);
806 want_dsense
= !!(cmd
[1] & 1) || scsi_debug_dsense
;
807 sbuff
= devip
->sense_buff
;
808 if ((iec_m_pg
[2] & 0x4) && (6 == (iec_m_pg
[3] & 0xf))) {
811 arr
[1] = 0x0; /* NO_SENSE in sense_key */
812 arr
[2] = THRESHOLD_EXCEEDED
;
813 arr
[3] = 0xff; /* TEST set and MRIE==6 */
816 arr
[2] = 0x0; /* NO_SENSE in sense_key */
817 arr
[7] = 0xa; /* 18 byte sense buffer */
818 arr
[12] = THRESHOLD_EXCEEDED
;
819 arr
[13] = 0xff; /* TEST set and MRIE==6 */
822 memcpy(arr
, sbuff
, SDEBUG_SENSE_LEN
);
823 if ((cmd
[1] & 1) && (! scsi_debug_dsense
)) {
824 /* DESC bit set and sense_buff in fixed format */
825 memset(arr
, 0, sizeof(arr
));
827 arr
[1] = sbuff
[2]; /* sense key */
828 arr
[2] = sbuff
[12]; /* asc */
829 arr
[3] = sbuff
[13]; /* ascq */
833 mk_sense_buffer(devip
, 0, NO_ADDITIONAL_SENSE
, 0);
834 return fill_from_dev_buffer(scp
, arr
, len
);
837 static int resp_start_stop(struct scsi_cmnd
* scp
,
838 struct sdebug_dev_info
* devip
)
840 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
841 int power_cond
, errsts
, start
;
843 if ((errsts
= check_readiness(scp
, 1, devip
)))
845 power_cond
= (cmd
[4] & 0xf0) >> 4;
847 mk_sense_buffer(devip
, ILLEGAL_REQUEST
, INVALID_FIELD_IN_CDB
,
849 return check_condition_result
;
852 if (start
== devip
->stopped
)
853 devip
->stopped
= !start
;
857 static sector_t
get_sdebug_capacity(void)
859 if (scsi_debug_virtual_gb
> 0)
860 return 2048 * 1024 * scsi_debug_virtual_gb
;
862 return sdebug_store_sectors
;
865 #define SDEBUG_READCAP_ARR_SZ 8
866 static int resp_readcap(struct scsi_cmnd
* scp
,
867 struct sdebug_dev_info
* devip
)
869 unsigned char arr
[SDEBUG_READCAP_ARR_SZ
];
873 if ((errsts
= check_readiness(scp
, 1, devip
)))
875 /* following just in case virtual_gb changed */
876 sdebug_capacity
= get_sdebug_capacity();
877 memset(arr
, 0, SDEBUG_READCAP_ARR_SZ
);
878 if (sdebug_capacity
< 0xffffffff) {
879 capac
= (unsigned int)sdebug_capacity
- 1;
880 arr
[0] = (capac
>> 24);
881 arr
[1] = (capac
>> 16) & 0xff;
882 arr
[2] = (capac
>> 8) & 0xff;
883 arr
[3] = capac
& 0xff;
890 arr
[6] = (scsi_debug_sector_size
>> 8) & 0xff;
891 arr
[7] = scsi_debug_sector_size
& 0xff;
892 return fill_from_dev_buffer(scp
, arr
, SDEBUG_READCAP_ARR_SZ
);
895 #define SDEBUG_READCAP16_ARR_SZ 32
896 static int resp_readcap16(struct scsi_cmnd
* scp
,
897 struct sdebug_dev_info
* devip
)
899 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
900 unsigned char arr
[SDEBUG_READCAP16_ARR_SZ
];
901 unsigned long long capac
;
902 int errsts
, k
, alloc_len
;
904 if ((errsts
= check_readiness(scp
, 1, devip
)))
906 alloc_len
= ((cmd
[10] << 24) + (cmd
[11] << 16) + (cmd
[12] << 8)
908 /* following just in case virtual_gb changed */
909 sdebug_capacity
= get_sdebug_capacity();
910 memset(arr
, 0, SDEBUG_READCAP16_ARR_SZ
);
911 capac
= sdebug_capacity
- 1;
912 for (k
= 0; k
< 8; ++k
, capac
>>= 8)
913 arr
[7 - k
] = capac
& 0xff;
914 arr
[8] = (scsi_debug_sector_size
>> 24) & 0xff;
915 arr
[9] = (scsi_debug_sector_size
>> 16) & 0xff;
916 arr
[10] = (scsi_debug_sector_size
>> 8) & 0xff;
917 arr
[11] = scsi_debug_sector_size
& 0xff;
918 return fill_from_dev_buffer(scp
, arr
,
919 min(alloc_len
, SDEBUG_READCAP16_ARR_SZ
));
922 #define SDEBUG_MAX_TGTPGS_ARR_SZ 1412
924 static int resp_report_tgtpgs(struct scsi_cmnd
* scp
,
925 struct sdebug_dev_info
* devip
)
927 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
929 int host_no
= devip
->sdbg_host
->shost
->host_no
;
930 int n
, ret
, alen
, rlen
;
931 int port_group_a
, port_group_b
, port_a
, port_b
;
933 alen
= ((cmd
[6] << 24) + (cmd
[7] << 16) + (cmd
[8] << 8)
936 arr
= kzalloc(SDEBUG_MAX_TGTPGS_ARR_SZ
, GFP_ATOMIC
);
938 return DID_REQUEUE
<< 16;
940 * EVPD page 0x88 states we have two ports, one
941 * real and a fake port with no device connected.
942 * So we create two port groups with one port each
943 * and set the group with port B to unavailable.
945 port_a
= 0x1; /* relative port A */
946 port_b
= 0x2; /* relative port B */
947 port_group_a
= (((host_no
+ 1) & 0x7f) << 8) +
948 (devip
->channel
& 0x7f);
949 port_group_b
= (((host_no
+ 1) & 0x7f) << 8) +
950 (devip
->channel
& 0x7f) + 0x80;
953 * The asymmetric access state is cycled according to the host_id.
956 if (0 == scsi_debug_vpd_use_hostno
) {
957 arr
[n
++] = host_no
% 3; /* Asymm access state */
958 arr
[n
++] = 0x0F; /* claim: all states are supported */
960 arr
[n
++] = 0x0; /* Active/Optimized path */
961 arr
[n
++] = 0x01; /* claim: only support active/optimized paths */
963 arr
[n
++] = (port_group_a
>> 8) & 0xff;
964 arr
[n
++] = port_group_a
& 0xff;
965 arr
[n
++] = 0; /* Reserved */
966 arr
[n
++] = 0; /* Status code */
967 arr
[n
++] = 0; /* Vendor unique */
968 arr
[n
++] = 0x1; /* One port per group */
969 arr
[n
++] = 0; /* Reserved */
970 arr
[n
++] = 0; /* Reserved */
971 arr
[n
++] = (port_a
>> 8) & 0xff;
972 arr
[n
++] = port_a
& 0xff;
973 arr
[n
++] = 3; /* Port unavailable */
974 arr
[n
++] = 0x08; /* claim: only unavailalbe paths are supported */
975 arr
[n
++] = (port_group_b
>> 8) & 0xff;
976 arr
[n
++] = port_group_b
& 0xff;
977 arr
[n
++] = 0; /* Reserved */
978 arr
[n
++] = 0; /* Status code */
979 arr
[n
++] = 0; /* Vendor unique */
980 arr
[n
++] = 0x1; /* One port per group */
981 arr
[n
++] = 0; /* Reserved */
982 arr
[n
++] = 0; /* Reserved */
983 arr
[n
++] = (port_b
>> 8) & 0xff;
984 arr
[n
++] = port_b
& 0xff;
987 arr
[0] = (rlen
>> 24) & 0xff;
988 arr
[1] = (rlen
>> 16) & 0xff;
989 arr
[2] = (rlen
>> 8) & 0xff;
990 arr
[3] = rlen
& 0xff;
993 * Return the smallest value of either
994 * - The allocated length
995 * - The constructed command length
996 * - The maximum array size
999 ret
= fill_from_dev_buffer(scp
, arr
,
1000 min(rlen
, SDEBUG_MAX_TGTPGS_ARR_SZ
));
1005 /* <<Following mode page info copied from ST318451LW>> */
1007 static int resp_err_recov_pg(unsigned char * p
, int pcontrol
, int target
)
1008 { /* Read-Write Error Recovery page for mode_sense */
1009 unsigned char err_recov_pg
[] = {0x1, 0xa, 0xc0, 11, 240, 0, 0, 0,
1012 memcpy(p
, err_recov_pg
, sizeof(err_recov_pg
));
1014 memset(p
+ 2, 0, sizeof(err_recov_pg
) - 2);
1015 return sizeof(err_recov_pg
);
1018 static int resp_disconnect_pg(unsigned char * p
, int pcontrol
, int target
)
1019 { /* Disconnect-Reconnect page for mode_sense */
1020 unsigned char disconnect_pg
[] = {0x2, 0xe, 128, 128, 0, 10, 0, 0,
1021 0, 0, 0, 0, 0, 0, 0, 0};
1023 memcpy(p
, disconnect_pg
, sizeof(disconnect_pg
));
1025 memset(p
+ 2, 0, sizeof(disconnect_pg
) - 2);
1026 return sizeof(disconnect_pg
);
1029 static int resp_format_pg(unsigned char * p
, int pcontrol
, int target
)
1030 { /* Format device page for mode_sense */
1031 unsigned char format_pg
[] = {0x3, 0x16, 0, 0, 0, 0, 0, 0,
1032 0, 0, 0, 0, 0, 0, 0, 0,
1033 0, 0, 0, 0, 0x40, 0, 0, 0};
1035 memcpy(p
, format_pg
, sizeof(format_pg
));
1036 p
[10] = (sdebug_sectors_per
>> 8) & 0xff;
1037 p
[11] = sdebug_sectors_per
& 0xff;
1038 p
[12] = (scsi_debug_sector_size
>> 8) & 0xff;
1039 p
[13] = scsi_debug_sector_size
& 0xff;
1040 if (DEV_REMOVEABLE(target
))
1041 p
[20] |= 0x20; /* should agree with INQUIRY */
1043 memset(p
+ 2, 0, sizeof(format_pg
) - 2);
1044 return sizeof(format_pg
);
1047 static int resp_caching_pg(unsigned char * p
, int pcontrol
, int target
)
1048 { /* Caching page for mode_sense */
1049 unsigned char caching_pg
[] = {0x8, 18, 0x14, 0, 0xff, 0xff, 0, 0,
1050 0xff, 0xff, 0xff, 0xff, 0x80, 0x14, 0, 0, 0, 0, 0, 0};
1052 memcpy(p
, caching_pg
, sizeof(caching_pg
));
1054 memset(p
+ 2, 0, sizeof(caching_pg
) - 2);
1055 return sizeof(caching_pg
);
1058 static int resp_ctrl_m_pg(unsigned char * p
, int pcontrol
, int target
)
1059 { /* Control mode page for mode_sense */
1060 unsigned char ch_ctrl_m_pg
[] = {/* 0xa, 10, */ 0x6, 0, 0, 0, 0, 0,
1062 unsigned char d_ctrl_m_pg
[] = {0xa, 10, 2, 0, 0, 0, 0, 0,
1065 if (scsi_debug_dsense
)
1066 ctrl_m_pg
[2] |= 0x4;
1068 ctrl_m_pg
[2] &= ~0x4;
1069 memcpy(p
, ctrl_m_pg
, sizeof(ctrl_m_pg
));
1071 memcpy(p
+ 2, ch_ctrl_m_pg
, sizeof(ch_ctrl_m_pg
));
1072 else if (2 == pcontrol
)
1073 memcpy(p
, d_ctrl_m_pg
, sizeof(d_ctrl_m_pg
));
1074 return sizeof(ctrl_m_pg
);
1078 static int resp_iec_m_pg(unsigned char * p
, int pcontrol
, int target
)
1079 { /* Informational Exceptions control mode page for mode_sense */
1080 unsigned char ch_iec_m_pg
[] = {/* 0x1c, 0xa, */ 0x4, 0xf, 0, 0, 0, 0,
1082 unsigned char d_iec_m_pg
[] = {0x1c, 0xa, 0x08, 0, 0, 0, 0, 0,
1085 memcpy(p
, iec_m_pg
, sizeof(iec_m_pg
));
1087 memcpy(p
+ 2, ch_iec_m_pg
, sizeof(ch_iec_m_pg
));
1088 else if (2 == pcontrol
)
1089 memcpy(p
, d_iec_m_pg
, sizeof(d_iec_m_pg
));
1090 return sizeof(iec_m_pg
);
1093 static int resp_sas_sf_m_pg(unsigned char * p
, int pcontrol
, int target
)
1094 { /* SAS SSP mode page - short format for mode_sense */
1095 unsigned char sas_sf_m_pg
[] = {0x19, 0x6,
1096 0x6, 0x0, 0x7, 0xd0, 0x0, 0x0};
1098 memcpy(p
, sas_sf_m_pg
, sizeof(sas_sf_m_pg
));
1100 memset(p
+ 2, 0, sizeof(sas_sf_m_pg
) - 2);
1101 return sizeof(sas_sf_m_pg
);
1105 static int resp_sas_pcd_m_spg(unsigned char * p
, int pcontrol
, int target
,
1107 { /* SAS phy control and discover mode page for mode_sense */
1108 unsigned char sas_pcd_m_pg
[] = {0x59, 0x1, 0, 0x64, 0, 0x6, 0, 2,
1109 0, 0, 0, 0, 0x10, 0x9, 0x8, 0x0,
1110 0x52, 0x22, 0x22, 0x20, 0x0, 0x0, 0x0, 0x0,
1111 0x51, 0x11, 0x11, 0x10, 0x0, 0x0, 0x0, 0x1,
1112 0x2, 0, 0, 0, 0, 0, 0, 0,
1113 0x88, 0x99, 0, 0, 0, 0, 0, 0,
1114 0, 0, 0, 0, 0, 0, 0, 0,
1115 0, 1, 0, 0, 0x10, 0x9, 0x8, 0x0,
1116 0x52, 0x22, 0x22, 0x20, 0x0, 0x0, 0x0, 0x0,
1117 0x51, 0x11, 0x11, 0x10, 0x0, 0x0, 0x0, 0x1,
1118 0x3, 0, 0, 0, 0, 0, 0, 0,
1119 0x88, 0x99, 0, 0, 0, 0, 0, 0,
1120 0, 0, 0, 0, 0, 0, 0, 0,
1124 port_a
= target_dev_id
+ 1;
1125 port_b
= port_a
+ 1;
1126 memcpy(p
, sas_pcd_m_pg
, sizeof(sas_pcd_m_pg
));
1127 p
[20] = (port_a
>> 24);
1128 p
[21] = (port_a
>> 16) & 0xff;
1129 p
[22] = (port_a
>> 8) & 0xff;
1130 p
[23] = port_a
& 0xff;
1131 p
[48 + 20] = (port_b
>> 24);
1132 p
[48 + 21] = (port_b
>> 16) & 0xff;
1133 p
[48 + 22] = (port_b
>> 8) & 0xff;
1134 p
[48 + 23] = port_b
& 0xff;
1136 memset(p
+ 4, 0, sizeof(sas_pcd_m_pg
) - 4);
1137 return sizeof(sas_pcd_m_pg
);
1140 static int resp_sas_sha_m_spg(unsigned char * p
, int pcontrol
)
1141 { /* SAS SSP shared protocol specific port mode subpage */
1142 unsigned char sas_sha_m_pg
[] = {0x59, 0x2, 0, 0xc, 0, 0x6, 0x10, 0,
1143 0, 0, 0, 0, 0, 0, 0, 0,
1146 memcpy(p
, sas_sha_m_pg
, sizeof(sas_sha_m_pg
));
1148 memset(p
+ 4, 0, sizeof(sas_sha_m_pg
) - 4);
1149 return sizeof(sas_sha_m_pg
);
1152 #define SDEBUG_MAX_MSENSE_SZ 256
1154 static int resp_mode_sense(struct scsi_cmnd
* scp
, int target
,
1155 struct sdebug_dev_info
* devip
)
1157 unsigned char dbd
, llbaa
;
1158 int pcontrol
, pcode
, subpcode
, bd_len
;
1159 unsigned char dev_spec
;
1160 int k
, alloc_len
, msense_6
, offset
, len
, errsts
, target_dev_id
;
1162 unsigned char arr
[SDEBUG_MAX_MSENSE_SZ
];
1163 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
1165 if ((errsts
= check_readiness(scp
, 1, devip
)))
1167 dbd
= !!(cmd
[1] & 0x8);
1168 pcontrol
= (cmd
[2] & 0xc0) >> 6;
1169 pcode
= cmd
[2] & 0x3f;
1171 msense_6
= (MODE_SENSE
== cmd
[0]);
1172 llbaa
= msense_6
? 0 : !!(cmd
[1] & 0x10);
1173 if ((0 == scsi_debug_ptype
) && (0 == dbd
))
1174 bd_len
= llbaa
? 16 : 8;
1177 alloc_len
= msense_6
? cmd
[4] : ((cmd
[7] << 8) | cmd
[8]);
1178 memset(arr
, 0, SDEBUG_MAX_MSENSE_SZ
);
1179 if (0x3 == pcontrol
) { /* Saving values not supported */
1180 mk_sense_buffer(devip
, ILLEGAL_REQUEST
, SAVING_PARAMS_UNSUP
,
1182 return check_condition_result
;
1184 target_dev_id
= ((devip
->sdbg_host
->shost
->host_no
+ 1) * 2000) +
1185 (devip
->target
* 1000) - 3;
1186 /* set DPOFUA bit for disks */
1187 if (0 == scsi_debug_ptype
)
1188 dev_spec
= (DEV_READONLY(target
) ? 0x80 : 0x0) | 0x10;
1198 arr
[4] = 0x1; /* set LONGLBA bit */
1199 arr
[7] = bd_len
; /* assume 255 or less */
1203 if ((bd_len
> 0) && (!sdebug_capacity
))
1204 sdebug_capacity
= get_sdebug_capacity();
1207 if (sdebug_capacity
> 0xfffffffe) {
1213 ap
[0] = (sdebug_capacity
>> 24) & 0xff;
1214 ap
[1] = (sdebug_capacity
>> 16) & 0xff;
1215 ap
[2] = (sdebug_capacity
>> 8) & 0xff;
1216 ap
[3] = sdebug_capacity
& 0xff;
1218 ap
[6] = (scsi_debug_sector_size
>> 8) & 0xff;
1219 ap
[7] = scsi_debug_sector_size
& 0xff;
1222 } else if (16 == bd_len
) {
1223 unsigned long long capac
= sdebug_capacity
;
1225 for (k
= 0; k
< 8; ++k
, capac
>>= 8)
1226 ap
[7 - k
] = capac
& 0xff;
1227 ap
[12] = (scsi_debug_sector_size
>> 24) & 0xff;
1228 ap
[13] = (scsi_debug_sector_size
>> 16) & 0xff;
1229 ap
[14] = (scsi_debug_sector_size
>> 8) & 0xff;
1230 ap
[15] = scsi_debug_sector_size
& 0xff;
1235 if ((subpcode
> 0x0) && (subpcode
< 0xff) && (0x19 != pcode
)) {
1236 /* TODO: Control Extension page */
1237 mk_sense_buffer(devip
, ILLEGAL_REQUEST
, INVALID_FIELD_IN_CDB
,
1239 return check_condition_result
;
1242 case 0x1: /* Read-Write error recovery page, direct access */
1243 len
= resp_err_recov_pg(ap
, pcontrol
, target
);
1246 case 0x2: /* Disconnect-Reconnect page, all devices */
1247 len
= resp_disconnect_pg(ap
, pcontrol
, target
);
1250 case 0x3: /* Format device page, direct access */
1251 len
= resp_format_pg(ap
, pcontrol
, target
);
1254 case 0x8: /* Caching page, direct access */
1255 len
= resp_caching_pg(ap
, pcontrol
, target
);
1258 case 0xa: /* Control Mode page, all devices */
1259 len
= resp_ctrl_m_pg(ap
, pcontrol
, target
);
1262 case 0x19: /* if spc==1 then sas phy, control+discover */
1263 if ((subpcode
> 0x2) && (subpcode
< 0xff)) {
1264 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1265 INVALID_FIELD_IN_CDB
, 0);
1266 return check_condition_result
;
1269 if ((0x0 == subpcode
) || (0xff == subpcode
))
1270 len
+= resp_sas_sf_m_pg(ap
+ len
, pcontrol
, target
);
1271 if ((0x1 == subpcode
) || (0xff == subpcode
))
1272 len
+= resp_sas_pcd_m_spg(ap
+ len
, pcontrol
, target
,
1274 if ((0x2 == subpcode
) || (0xff == subpcode
))
1275 len
+= resp_sas_sha_m_spg(ap
+ len
, pcontrol
);
1278 case 0x1c: /* Informational Exceptions Mode page, all devices */
1279 len
= resp_iec_m_pg(ap
, pcontrol
, target
);
1282 case 0x3f: /* Read all Mode pages */
1283 if ((0 == subpcode
) || (0xff == subpcode
)) {
1284 len
= resp_err_recov_pg(ap
, pcontrol
, target
);
1285 len
+= resp_disconnect_pg(ap
+ len
, pcontrol
, target
);
1286 len
+= resp_format_pg(ap
+ len
, pcontrol
, target
);
1287 len
+= resp_caching_pg(ap
+ len
, pcontrol
, target
);
1288 len
+= resp_ctrl_m_pg(ap
+ len
, pcontrol
, target
);
1289 len
+= resp_sas_sf_m_pg(ap
+ len
, pcontrol
, target
);
1290 if (0xff == subpcode
) {
1291 len
+= resp_sas_pcd_m_spg(ap
+ len
, pcontrol
,
1292 target
, target_dev_id
);
1293 len
+= resp_sas_sha_m_spg(ap
+ len
, pcontrol
);
1295 len
+= resp_iec_m_pg(ap
+ len
, pcontrol
, target
);
1297 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1298 INVALID_FIELD_IN_CDB
, 0);
1299 return check_condition_result
;
1304 mk_sense_buffer(devip
, ILLEGAL_REQUEST
, INVALID_FIELD_IN_CDB
,
1306 return check_condition_result
;
1309 arr
[0] = offset
- 1;
1311 arr
[0] = ((offset
- 2) >> 8) & 0xff;
1312 arr
[1] = (offset
- 2) & 0xff;
1314 return fill_from_dev_buffer(scp
, arr
, min(alloc_len
, offset
));
1317 #define SDEBUG_MAX_MSELECT_SZ 512
1319 static int resp_mode_select(struct scsi_cmnd
* scp
, int mselect6
,
1320 struct sdebug_dev_info
* devip
)
1322 int pf
, sp
, ps
, md_len
, bd_len
, off
, spf
, pg_len
;
1323 int param_len
, res
, errsts
, mpage
;
1324 unsigned char arr
[SDEBUG_MAX_MSELECT_SZ
];
1325 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
1327 if ((errsts
= check_readiness(scp
, 1, devip
)))
1329 memset(arr
, 0, sizeof(arr
));
1332 param_len
= mselect6
? cmd
[4] : ((cmd
[7] << 8) + cmd
[8]);
1333 if ((0 == pf
) || sp
|| (param_len
> SDEBUG_MAX_MSELECT_SZ
)) {
1334 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1335 INVALID_FIELD_IN_CDB
, 0);
1336 return check_condition_result
;
1338 res
= fetch_to_dev_buffer(scp
, arr
, param_len
);
1340 return (DID_ERROR
<< 16);
1341 else if ((res
< param_len
) &&
1342 (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
))
1343 printk(KERN_INFO
"scsi_debug: mode_select: cdb indicated=%d, "
1344 " IO sent=%d bytes\n", param_len
, res
);
1345 md_len
= mselect6
? (arr
[0] + 1) : ((arr
[0] << 8) + arr
[1] + 2);
1346 bd_len
= mselect6
? arr
[3] : ((arr
[6] << 8) + arr
[7]);
1348 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1349 INVALID_FIELD_IN_PARAM_LIST
, 0);
1350 return check_condition_result
;
1352 off
= bd_len
+ (mselect6
? 4 : 8);
1353 mpage
= arr
[off
] & 0x3f;
1354 ps
= !!(arr
[off
] & 0x80);
1356 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1357 INVALID_FIELD_IN_PARAM_LIST
, 0);
1358 return check_condition_result
;
1360 spf
= !!(arr
[off
] & 0x40);
1361 pg_len
= spf
? ((arr
[off
+ 2] << 8) + arr
[off
+ 3] + 4) :
1363 if ((pg_len
+ off
) > param_len
) {
1364 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1365 PARAMETER_LIST_LENGTH_ERR
, 0);
1366 return check_condition_result
;
1369 case 0xa: /* Control Mode page */
1370 if (ctrl_m_pg
[1] == arr
[off
+ 1]) {
1371 memcpy(ctrl_m_pg
+ 2, arr
+ off
+ 2,
1372 sizeof(ctrl_m_pg
) - 2);
1373 scsi_debug_dsense
= !!(ctrl_m_pg
[2] & 0x4);
1377 case 0x1c: /* Informational Exceptions Mode page */
1378 if (iec_m_pg
[1] == arr
[off
+ 1]) {
1379 memcpy(iec_m_pg
+ 2, arr
+ off
+ 2,
1380 sizeof(iec_m_pg
) - 2);
1387 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1388 INVALID_FIELD_IN_PARAM_LIST
, 0);
1389 return check_condition_result
;
1392 static int resp_temp_l_pg(unsigned char * arr
)
1394 unsigned char temp_l_pg
[] = {0x0, 0x0, 0x3, 0x2, 0x0, 38,
1395 0x0, 0x1, 0x3, 0x2, 0x0, 65,
1398 memcpy(arr
, temp_l_pg
, sizeof(temp_l_pg
));
1399 return sizeof(temp_l_pg
);
1402 static int resp_ie_l_pg(unsigned char * arr
)
1404 unsigned char ie_l_pg
[] = {0x0, 0x0, 0x3, 0x3, 0x0, 0x0, 38,
1407 memcpy(arr
, ie_l_pg
, sizeof(ie_l_pg
));
1408 if (iec_m_pg
[2] & 0x4) { /* TEST bit set */
1409 arr
[4] = THRESHOLD_EXCEEDED
;
1412 return sizeof(ie_l_pg
);
1415 #define SDEBUG_MAX_LSENSE_SZ 512
1417 static int resp_log_sense(struct scsi_cmnd
* scp
,
1418 struct sdebug_dev_info
* devip
)
1420 int ppc
, sp
, pcontrol
, pcode
, subpcode
, alloc_len
, errsts
, len
, n
;
1421 unsigned char arr
[SDEBUG_MAX_LSENSE_SZ
];
1422 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
1424 if ((errsts
= check_readiness(scp
, 1, devip
)))
1426 memset(arr
, 0, sizeof(arr
));
1430 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1431 INVALID_FIELD_IN_CDB
, 0);
1432 return check_condition_result
;
1434 pcontrol
= (cmd
[2] & 0xc0) >> 6;
1435 pcode
= cmd
[2] & 0x3f;
1436 subpcode
= cmd
[3] & 0xff;
1437 alloc_len
= (cmd
[7] << 8) + cmd
[8];
1439 if (0 == subpcode
) {
1441 case 0x0: /* Supported log pages log page */
1443 arr
[n
++] = 0x0; /* this page */
1444 arr
[n
++] = 0xd; /* Temperature */
1445 arr
[n
++] = 0x2f; /* Informational exceptions */
1448 case 0xd: /* Temperature log page */
1449 arr
[3] = resp_temp_l_pg(arr
+ 4);
1451 case 0x2f: /* Informational exceptions log page */
1452 arr
[3] = resp_ie_l_pg(arr
+ 4);
1455 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1456 INVALID_FIELD_IN_CDB
, 0);
1457 return check_condition_result
;
1459 } else if (0xff == subpcode
) {
1463 case 0x0: /* Supported log pages and subpages log page */
1466 arr
[n
++] = 0x0; /* 0,0 page */
1468 arr
[n
++] = 0xff; /* this page */
1470 arr
[n
++] = 0x0; /* Temperature */
1472 arr
[n
++] = 0x0; /* Informational exceptions */
1475 case 0xd: /* Temperature subpages */
1478 arr
[n
++] = 0x0; /* Temperature */
1481 case 0x2f: /* Informational exceptions subpages */
1484 arr
[n
++] = 0x0; /* Informational exceptions */
1488 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1489 INVALID_FIELD_IN_CDB
, 0);
1490 return check_condition_result
;
1493 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
1494 INVALID_FIELD_IN_CDB
, 0);
1495 return check_condition_result
;
1497 len
= min(((arr
[2] << 8) + arr
[3]) + 4, alloc_len
);
1498 return fill_from_dev_buffer(scp
, arr
,
1499 min(len
, SDEBUG_MAX_INQ_ARR_SZ
));
1502 static int check_device_access_params(struct sdebug_dev_info
*devi
,
1503 unsigned long long lba
, unsigned int num
)
1505 if (lba
+ num
> sdebug_capacity
) {
1506 mk_sense_buffer(devi
, ILLEGAL_REQUEST
, ADDR_OUT_OF_RANGE
, 0);
1507 return check_condition_result
;
1509 /* transfer length excessive (tie in to block limits VPD page) */
1510 if (num
> sdebug_store_sectors
) {
1511 mk_sense_buffer(devi
, ILLEGAL_REQUEST
, INVALID_FIELD_IN_CDB
, 0);
1512 return check_condition_result
;
1517 static int do_device_access(struct scsi_cmnd
*scmd
,
1518 struct sdebug_dev_info
*devi
,
1519 unsigned long long lba
, unsigned int num
, int write
)
1522 unsigned int block
, rest
= 0;
1523 int (*func
)(struct scsi_cmnd
*, unsigned char *, int);
1525 func
= write
? fetch_to_dev_buffer
: fill_from_dev_buffer
;
1527 block
= do_div(lba
, sdebug_store_sectors
);
1528 if (block
+ num
> sdebug_store_sectors
)
1529 rest
= block
+ num
- sdebug_store_sectors
;
1531 ret
= func(scmd
, fake_storep
+ (block
* scsi_debug_sector_size
),
1532 (num
- rest
) * scsi_debug_sector_size
);
1534 ret
= func(scmd
, fake_storep
, rest
* scsi_debug_sector_size
);
1539 static int resp_read(struct scsi_cmnd
*SCpnt
, unsigned long long lba
,
1540 unsigned int num
, struct sdebug_dev_info
*devip
)
1542 unsigned long iflags
;
1545 ret
= check_device_access_params(devip
, lba
, num
);
1549 if ((SCSI_DEBUG_OPT_MEDIUM_ERR
& scsi_debug_opts
) &&
1550 (lba
<= OPT_MEDIUM_ERR_ADDR
) &&
1551 ((lba
+ num
) > OPT_MEDIUM_ERR_ADDR
)) {
1552 /* claim unrecoverable read error */
1553 mk_sense_buffer(devip
, MEDIUM_ERROR
, UNRECOVERED_READ_ERR
,
1555 /* set info field and valid bit for fixed descriptor */
1556 if (0x70 == (devip
->sense_buff
[0] & 0x7f)) {
1557 devip
->sense_buff
[0] |= 0x80; /* Valid bit */
1558 ret
= OPT_MEDIUM_ERR_ADDR
;
1559 devip
->sense_buff
[3] = (ret
>> 24) & 0xff;
1560 devip
->sense_buff
[4] = (ret
>> 16) & 0xff;
1561 devip
->sense_buff
[5] = (ret
>> 8) & 0xff;
1562 devip
->sense_buff
[6] = ret
& 0xff;
1564 return check_condition_result
;
1566 read_lock_irqsave(&atomic_rw
, iflags
);
1567 ret
= do_device_access(SCpnt
, devip
, lba
, num
, 0);
1568 read_unlock_irqrestore(&atomic_rw
, iflags
);
1572 static int resp_write(struct scsi_cmnd
*SCpnt
, unsigned long long lba
,
1573 unsigned int num
, struct sdebug_dev_info
*devip
)
1575 unsigned long iflags
;
1578 ret
= check_device_access_params(devip
, lba
, num
);
1582 write_lock_irqsave(&atomic_rw
, iflags
);
1583 ret
= do_device_access(SCpnt
, devip
, lba
, num
, 1);
1584 write_unlock_irqrestore(&atomic_rw
, iflags
);
1586 return (DID_ERROR
<< 16);
1587 else if ((ret
< (num
* scsi_debug_sector_size
)) &&
1588 (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
))
1589 printk(KERN_INFO
"scsi_debug: write: cdb indicated=%u, "
1590 " IO sent=%d bytes\n", num
* scsi_debug_sector_size
, ret
);
1594 #define SDEBUG_RLUN_ARR_SZ 256
1596 static int resp_report_luns(struct scsi_cmnd
* scp
,
1597 struct sdebug_dev_info
* devip
)
1599 unsigned int alloc_len
;
1600 int lun_cnt
, i
, upper
, num
, n
, wlun
, lun
;
1601 unsigned char *cmd
= (unsigned char *)scp
->cmnd
;
1602 int select_report
= (int)cmd
[2];
1603 struct scsi_lun
*one_lun
;
1604 unsigned char arr
[SDEBUG_RLUN_ARR_SZ
];
1605 unsigned char * max_addr
;
1607 alloc_len
= cmd
[9] + (cmd
[8] << 8) + (cmd
[7] << 16) + (cmd
[6] << 24);
1608 if ((alloc_len
< 4) || (select_report
> 2)) {
1609 mk_sense_buffer(devip
, ILLEGAL_REQUEST
, INVALID_FIELD_IN_CDB
,
1611 return check_condition_result
;
1613 /* can produce response with up to 16k luns (lun 0 to lun 16383) */
1614 memset(arr
, 0, SDEBUG_RLUN_ARR_SZ
);
1615 lun_cnt
= scsi_debug_max_luns
;
1616 if (1 == select_report
)
1618 else if (scsi_debug_no_lun_0
&& (lun_cnt
> 0))
1620 wlun
= (select_report
> 0) ? 1 : 0;
1621 num
= lun_cnt
+ wlun
;
1622 arr
[2] = ((sizeof(struct scsi_lun
) * num
) >> 8) & 0xff;
1623 arr
[3] = (sizeof(struct scsi_lun
) * num
) & 0xff;
1624 n
= min((int)((SDEBUG_RLUN_ARR_SZ
- 8) /
1625 sizeof(struct scsi_lun
)), num
);
1630 one_lun
= (struct scsi_lun
*) &arr
[8];
1631 max_addr
= arr
+ SDEBUG_RLUN_ARR_SZ
;
1632 for (i
= 0, lun
= (scsi_debug_no_lun_0
? 1 : 0);
1633 ((i
< lun_cnt
) && ((unsigned char *)(one_lun
+ i
) < max_addr
));
1635 upper
= (lun
>> 8) & 0x3f;
1637 one_lun
[i
].scsi_lun
[0] =
1638 (upper
| (SAM2_LUN_ADDRESS_METHOD
<< 6));
1639 one_lun
[i
].scsi_lun
[1] = lun
& 0xff;
1642 one_lun
[i
].scsi_lun
[0] = (SAM2_WLUN_REPORT_LUNS
>> 8) & 0xff;
1643 one_lun
[i
].scsi_lun
[1] = SAM2_WLUN_REPORT_LUNS
& 0xff;
1646 alloc_len
= (unsigned char *)(one_lun
+ i
) - arr
;
1647 return fill_from_dev_buffer(scp
, arr
,
1648 min((int)alloc_len
, SDEBUG_RLUN_ARR_SZ
));
1651 static int resp_xdwriteread(struct scsi_cmnd
*scp
, unsigned long long lba
,
1652 unsigned int num
, struct sdebug_dev_info
*devip
)
1655 unsigned char *kaddr
, *buf
;
1656 unsigned int offset
;
1657 struct scatterlist
*sg
;
1658 struct scsi_data_buffer
*sdb
= scsi_in(scp
);
1660 /* better not to use temporary buffer. */
1661 buf
= kmalloc(scsi_bufflen(scp
), GFP_ATOMIC
);
1665 scsi_sg_copy_to_buffer(scp
, buf
, scsi_bufflen(scp
));
1668 for_each_sg(sdb
->table
.sgl
, sg
, sdb
->table
.nents
, i
) {
1669 kaddr
= (unsigned char *)kmap_atomic(sg_page(sg
), KM_USER0
);
1673 for (j
= 0; j
< sg
->length
; j
++)
1674 *(kaddr
+ sg
->offset
+ j
) ^= *(buf
+ offset
+ j
);
1676 offset
+= sg
->length
;
1677 kunmap_atomic(kaddr
, KM_USER0
);
1686 /* When timer goes off this function is called. */
1687 static void timer_intr_handler(unsigned long indx
)
1689 struct sdebug_queued_cmd
* sqcp
;
1690 unsigned long iflags
;
1692 if (indx
>= SCSI_DEBUG_CANQUEUE
) {
1693 printk(KERN_ERR
"scsi_debug:timer_intr_handler: indx too "
1697 spin_lock_irqsave(&queued_arr_lock
, iflags
);
1698 sqcp
= &queued_arr
[(int)indx
];
1699 if (! sqcp
->in_use
) {
1700 printk(KERN_ERR
"scsi_debug:timer_intr_handler: Unexpected "
1702 spin_unlock_irqrestore(&queued_arr_lock
, iflags
);
1706 if (sqcp
->done_funct
) {
1707 sqcp
->a_cmnd
->result
= sqcp
->scsi_result
;
1708 sqcp
->done_funct(sqcp
->a_cmnd
); /* callback to mid level */
1710 sqcp
->done_funct
= NULL
;
1711 spin_unlock_irqrestore(&queued_arr_lock
, iflags
);
1715 static struct sdebug_dev_info
*
1716 sdebug_device_create(struct sdebug_host_info
*sdbg_host
, gfp_t flags
)
1718 struct sdebug_dev_info
*devip
;
1720 devip
= kzalloc(sizeof(*devip
), flags
);
1722 devip
->sdbg_host
= sdbg_host
;
1723 list_add_tail(&devip
->dev_list
, &sdbg_host
->dev_info_list
);
1728 static struct sdebug_dev_info
* devInfoReg(struct scsi_device
* sdev
)
1730 struct sdebug_host_info
* sdbg_host
;
1731 struct sdebug_dev_info
* open_devip
= NULL
;
1732 struct sdebug_dev_info
* devip
=
1733 (struct sdebug_dev_info
*)sdev
->hostdata
;
1737 sdbg_host
= *(struct sdebug_host_info
**)shost_priv(sdev
->host
);
1739 printk(KERN_ERR
"Host info NULL\n");
1742 list_for_each_entry(devip
, &sdbg_host
->dev_info_list
, dev_list
) {
1743 if ((devip
->used
) && (devip
->channel
== sdev
->channel
) &&
1744 (devip
->target
== sdev
->id
) &&
1745 (devip
->lun
== sdev
->lun
))
1748 if ((!devip
->used
) && (!open_devip
))
1752 if (!open_devip
) { /* try and make a new one */
1753 open_devip
= sdebug_device_create(sdbg_host
, GFP_ATOMIC
);
1755 printk(KERN_ERR
"%s: out of memory at line %d\n",
1756 __func__
, __LINE__
);
1761 open_devip
->channel
= sdev
->channel
;
1762 open_devip
->target
= sdev
->id
;
1763 open_devip
->lun
= sdev
->lun
;
1764 open_devip
->sdbg_host
= sdbg_host
;
1765 open_devip
->reset
= 1;
1766 open_devip
->used
= 1;
1767 memset(open_devip
->sense_buff
, 0, SDEBUG_SENSE_LEN
);
1768 if (scsi_debug_dsense
)
1769 open_devip
->sense_buff
[0] = 0x72;
1771 open_devip
->sense_buff
[0] = 0x70;
1772 open_devip
->sense_buff
[7] = 0xa;
1774 if (sdev
->lun
== SAM2_WLUN_REPORT_LUNS
)
1775 open_devip
->wlun
= SAM2_WLUN_REPORT_LUNS
& 0xff;
1780 static int scsi_debug_slave_alloc(struct scsi_device
*sdp
)
1782 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
1783 printk(KERN_INFO
"scsi_debug: slave_alloc <%u %u %u %u>\n",
1784 sdp
->host
->host_no
, sdp
->channel
, sdp
->id
, sdp
->lun
);
1785 queue_flag_set_unlocked(QUEUE_FLAG_BIDI
, sdp
->request_queue
);
1789 static int scsi_debug_slave_configure(struct scsi_device
*sdp
)
1791 struct sdebug_dev_info
*devip
;
1793 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
1794 printk(KERN_INFO
"scsi_debug: slave_configure <%u %u %u %u>\n",
1795 sdp
->host
->host_no
, sdp
->channel
, sdp
->id
, sdp
->lun
);
1796 if (sdp
->host
->max_cmd_len
!= SCSI_DEBUG_MAX_CMD_LEN
)
1797 sdp
->host
->max_cmd_len
= SCSI_DEBUG_MAX_CMD_LEN
;
1798 devip
= devInfoReg(sdp
);
1800 return 1; /* no resources, will be marked offline */
1801 sdp
->hostdata
= devip
;
1802 if (sdp
->host
->cmd_per_lun
)
1803 scsi_adjust_queue_depth(sdp
, SDEBUG_TAGGED_QUEUING
,
1804 sdp
->host
->cmd_per_lun
);
1805 blk_queue_max_segment_size(sdp
->request_queue
, 256 * 1024);
1809 static void scsi_debug_slave_destroy(struct scsi_device
*sdp
)
1811 struct sdebug_dev_info
*devip
=
1812 (struct sdebug_dev_info
*)sdp
->hostdata
;
1814 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
1815 printk(KERN_INFO
"scsi_debug: slave_destroy <%u %u %u %u>\n",
1816 sdp
->host
->host_no
, sdp
->channel
, sdp
->id
, sdp
->lun
);
1818 /* make this slot avaliable for re-use */
1820 sdp
->hostdata
= NULL
;
1824 /* Returns 1 if found 'cmnd' and deleted its timer. else returns 0 */
1825 static int stop_queued_cmnd(struct scsi_cmnd
*cmnd
)
1827 unsigned long iflags
;
1829 struct sdebug_queued_cmd
*sqcp
;
1831 spin_lock_irqsave(&queued_arr_lock
, iflags
);
1832 for (k
= 0; k
< SCSI_DEBUG_CANQUEUE
; ++k
) {
1833 sqcp
= &queued_arr
[k
];
1834 if (sqcp
->in_use
&& (cmnd
== sqcp
->a_cmnd
)) {
1835 del_timer_sync(&sqcp
->cmnd_timer
);
1837 sqcp
->a_cmnd
= NULL
;
1841 spin_unlock_irqrestore(&queued_arr_lock
, iflags
);
1842 return (k
< SCSI_DEBUG_CANQUEUE
) ? 1 : 0;
1845 /* Deletes (stops) timers of all queued commands */
1846 static void stop_all_queued(void)
1848 unsigned long iflags
;
1850 struct sdebug_queued_cmd
*sqcp
;
1852 spin_lock_irqsave(&queued_arr_lock
, iflags
);
1853 for (k
= 0; k
< SCSI_DEBUG_CANQUEUE
; ++k
) {
1854 sqcp
= &queued_arr
[k
];
1855 if (sqcp
->in_use
&& sqcp
->a_cmnd
) {
1856 del_timer_sync(&sqcp
->cmnd_timer
);
1858 sqcp
->a_cmnd
= NULL
;
1861 spin_unlock_irqrestore(&queued_arr_lock
, iflags
);
1864 static int scsi_debug_abort(struct scsi_cmnd
* SCpnt
)
1866 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
1867 printk(KERN_INFO
"scsi_debug: abort\n");
1869 stop_queued_cmnd(SCpnt
);
1873 static int scsi_debug_biosparam(struct scsi_device
*sdev
,
1874 struct block_device
* bdev
, sector_t capacity
, int *info
)
1879 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
1880 printk(KERN_INFO
"scsi_debug: biosparam\n");
1881 buf
= scsi_bios_ptable(bdev
);
1883 res
= scsi_partsize(buf
, capacity
,
1884 &info
[2], &info
[0], &info
[1]);
1889 info
[0] = sdebug_heads
;
1890 info
[1] = sdebug_sectors_per
;
1891 info
[2] = sdebug_cylinders_per
;
1895 static int scsi_debug_device_reset(struct scsi_cmnd
* SCpnt
)
1897 struct sdebug_dev_info
* devip
;
1899 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
1900 printk(KERN_INFO
"scsi_debug: device_reset\n");
1903 devip
= devInfoReg(SCpnt
->device
);
1910 static int scsi_debug_bus_reset(struct scsi_cmnd
* SCpnt
)
1912 struct sdebug_host_info
*sdbg_host
;
1913 struct sdebug_dev_info
* dev_info
;
1914 struct scsi_device
* sdp
;
1915 struct Scsi_Host
* hp
;
1917 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
1918 printk(KERN_INFO
"scsi_debug: bus_reset\n");
1920 if (SCpnt
&& ((sdp
= SCpnt
->device
)) && ((hp
= sdp
->host
))) {
1921 sdbg_host
= *(struct sdebug_host_info
**)shost_priv(hp
);
1923 list_for_each_entry(dev_info
,
1924 &sdbg_host
->dev_info_list
,
1926 dev_info
->reset
= 1;
1932 static int scsi_debug_host_reset(struct scsi_cmnd
* SCpnt
)
1934 struct sdebug_host_info
* sdbg_host
;
1935 struct sdebug_dev_info
* dev_info
;
1937 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
1938 printk(KERN_INFO
"scsi_debug: host_reset\n");
1940 spin_lock(&sdebug_host_list_lock
);
1941 list_for_each_entry(sdbg_host
, &sdebug_host_list
, host_list
) {
1942 list_for_each_entry(dev_info
, &sdbg_host
->dev_info_list
,
1944 dev_info
->reset
= 1;
1946 spin_unlock(&sdebug_host_list_lock
);
1951 /* Initializes timers in queued array */
1952 static void __init
init_all_queued(void)
1954 unsigned long iflags
;
1956 struct sdebug_queued_cmd
* sqcp
;
1958 spin_lock_irqsave(&queued_arr_lock
, iflags
);
1959 for (k
= 0; k
< SCSI_DEBUG_CANQUEUE
; ++k
) {
1960 sqcp
= &queued_arr
[k
];
1961 init_timer(&sqcp
->cmnd_timer
);
1963 sqcp
->a_cmnd
= NULL
;
1965 spin_unlock_irqrestore(&queued_arr_lock
, iflags
);
1968 static void __init
sdebug_build_parts(unsigned char *ramp
,
1969 unsigned long store_size
)
1971 struct partition
* pp
;
1972 int starts
[SDEBUG_MAX_PARTS
+ 2];
1973 int sectors_per_part
, num_sectors
, k
;
1974 int heads_by_sects
, start_sec
, end_sec
;
1976 /* assume partition table already zeroed */
1977 if ((scsi_debug_num_parts
< 1) || (store_size
< 1048576))
1979 if (scsi_debug_num_parts
> SDEBUG_MAX_PARTS
) {
1980 scsi_debug_num_parts
= SDEBUG_MAX_PARTS
;
1981 printk(KERN_WARNING
"scsi_debug:build_parts: reducing "
1982 "partitions to %d\n", SDEBUG_MAX_PARTS
);
1984 num_sectors
= (int)sdebug_store_sectors
;
1985 sectors_per_part
= (num_sectors
- sdebug_sectors_per
)
1986 / scsi_debug_num_parts
;
1987 heads_by_sects
= sdebug_heads
* sdebug_sectors_per
;
1988 starts
[0] = sdebug_sectors_per
;
1989 for (k
= 1; k
< scsi_debug_num_parts
; ++k
)
1990 starts
[k
] = ((k
* sectors_per_part
) / heads_by_sects
)
1992 starts
[scsi_debug_num_parts
] = num_sectors
;
1993 starts
[scsi_debug_num_parts
+ 1] = 0;
1995 ramp
[510] = 0x55; /* magic partition markings */
1997 pp
= (struct partition
*)(ramp
+ 0x1be);
1998 for (k
= 0; starts
[k
+ 1]; ++k
, ++pp
) {
1999 start_sec
= starts
[k
];
2000 end_sec
= starts
[k
+ 1] - 1;
2003 pp
->cyl
= start_sec
/ heads_by_sects
;
2004 pp
->head
= (start_sec
- (pp
->cyl
* heads_by_sects
))
2005 / sdebug_sectors_per
;
2006 pp
->sector
= (start_sec
% sdebug_sectors_per
) + 1;
2008 pp
->end_cyl
= end_sec
/ heads_by_sects
;
2009 pp
->end_head
= (end_sec
- (pp
->end_cyl
* heads_by_sects
))
2010 / sdebug_sectors_per
;
2011 pp
->end_sector
= (end_sec
% sdebug_sectors_per
) + 1;
2013 pp
->start_sect
= start_sec
;
2014 pp
->nr_sects
= end_sec
- start_sec
+ 1;
2015 pp
->sys_ind
= 0x83; /* plain Linux partition */
2019 static int schedule_resp(struct scsi_cmnd
* cmnd
,
2020 struct sdebug_dev_info
* devip
,
2021 done_funct_t done
, int scsi_result
, int delta_jiff
)
2023 if ((SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
) && cmnd
) {
2025 struct scsi_device
* sdp
= cmnd
->device
;
2027 printk(KERN_INFO
"scsi_debug: <%u %u %u %u> "
2028 "non-zero result=0x%x\n", sdp
->host
->host_no
,
2029 sdp
->channel
, sdp
->id
, sdp
->lun
, scsi_result
);
2032 if (cmnd
&& devip
) {
2033 /* simulate autosense by this driver */
2034 if (SAM_STAT_CHECK_CONDITION
== (scsi_result
& 0xff))
2035 memcpy(cmnd
->sense_buffer
, devip
->sense_buff
,
2036 (SCSI_SENSE_BUFFERSIZE
> SDEBUG_SENSE_LEN
) ?
2037 SDEBUG_SENSE_LEN
: SCSI_SENSE_BUFFERSIZE
);
2039 if (delta_jiff
<= 0) {
2041 cmnd
->result
= scsi_result
;
2046 unsigned long iflags
;
2048 struct sdebug_queued_cmd
* sqcp
= NULL
;
2050 spin_lock_irqsave(&queued_arr_lock
, iflags
);
2051 for (k
= 0; k
< SCSI_DEBUG_CANQUEUE
; ++k
) {
2052 sqcp
= &queued_arr
[k
];
2056 if (k
>= SCSI_DEBUG_CANQUEUE
) {
2057 spin_unlock_irqrestore(&queued_arr_lock
, iflags
);
2058 printk(KERN_WARNING
"scsi_debug: can_queue exceeded\n");
2059 return 1; /* report busy to mid level */
2062 sqcp
->a_cmnd
= cmnd
;
2063 sqcp
->scsi_result
= scsi_result
;
2064 sqcp
->done_funct
= done
;
2065 sqcp
->cmnd_timer
.function
= timer_intr_handler
;
2066 sqcp
->cmnd_timer
.data
= k
;
2067 sqcp
->cmnd_timer
.expires
= jiffies
+ delta_jiff
;
2068 add_timer(&sqcp
->cmnd_timer
);
2069 spin_unlock_irqrestore(&queued_arr_lock
, iflags
);
2075 /* Note: The following macros create attribute files in the
2076 /sys/module/scsi_debug/parameters directory. Unfortunately this
2077 driver is unaware of a change and cannot trigger auxiliary actions
2078 as it can when the corresponding attribute in the
2079 /sys/bus/pseudo/drivers/scsi_debug directory is changed.
2081 module_param_named(add_host
, scsi_debug_add_host
, int, S_IRUGO
| S_IWUSR
);
2082 module_param_named(delay
, scsi_debug_delay
, int, S_IRUGO
| S_IWUSR
);
2083 module_param_named(dev_size_mb
, scsi_debug_dev_size_mb
, int, S_IRUGO
);
2084 module_param_named(dsense
, scsi_debug_dsense
, int, S_IRUGO
| S_IWUSR
);
2085 module_param_named(every_nth
, scsi_debug_every_nth
, int, S_IRUGO
| S_IWUSR
);
2086 module_param_named(fake_rw
, scsi_debug_fake_rw
, int, S_IRUGO
| S_IWUSR
);
2087 module_param_named(max_luns
, scsi_debug_max_luns
, int, S_IRUGO
| S_IWUSR
);
2088 module_param_named(no_lun_0
, scsi_debug_no_lun_0
, int, S_IRUGO
| S_IWUSR
);
2089 module_param_named(num_parts
, scsi_debug_num_parts
, int, S_IRUGO
);
2090 module_param_named(num_tgts
, scsi_debug_num_tgts
, int, S_IRUGO
| S_IWUSR
);
2091 module_param_named(opts
, scsi_debug_opts
, int, S_IRUGO
| S_IWUSR
);
2092 module_param_named(ptype
, scsi_debug_ptype
, int, S_IRUGO
| S_IWUSR
);
2093 module_param_named(scsi_level
, scsi_debug_scsi_level
, int, S_IRUGO
);
2094 module_param_named(virtual_gb
, scsi_debug_virtual_gb
, int, S_IRUGO
| S_IWUSR
);
2095 module_param_named(vpd_use_hostno
, scsi_debug_vpd_use_hostno
, int,
2097 module_param_named(sector_size
, scsi_debug_sector_size
, int, S_IRUGO
);
2099 MODULE_AUTHOR("Eric Youngdale + Douglas Gilbert");
2100 MODULE_DESCRIPTION("SCSI debug adapter driver");
2101 MODULE_LICENSE("GPL");
2102 MODULE_VERSION(SCSI_DEBUG_VERSION
);
2104 MODULE_PARM_DESC(add_host
, "0..127 hosts allowed(def=1)");
2105 MODULE_PARM_DESC(delay
, "# of jiffies to delay response(def=1)");
2106 MODULE_PARM_DESC(dev_size_mb
, "size in MB of ram shared by devs(def=8)");
2107 MODULE_PARM_DESC(dsense
, "use descriptor sense format(def=0 -> fixed)");
2108 MODULE_PARM_DESC(every_nth
, "timeout every nth command(def=0)");
2109 MODULE_PARM_DESC(fake_rw
, "fake reads/writes instead of copying (def=0)");
2110 MODULE_PARM_DESC(max_luns
, "number of LUNs per target to simulate(def=1)");
2111 MODULE_PARM_DESC(no_lun_0
, "no LU number 0 (def=0 -> have lun 0)");
2112 MODULE_PARM_DESC(num_parts
, "number of partitions(def=0)");
2113 MODULE_PARM_DESC(num_tgts
, "number of targets per host to simulate(def=1)");
2114 MODULE_PARM_DESC(opts
, "1->noise, 2->medium_err, 4->timeout, 8->recovered_err... (def=0)");
2115 MODULE_PARM_DESC(ptype
, "SCSI peripheral type(def=0[disk])");
2116 MODULE_PARM_DESC(scsi_level
, "SCSI level to simulate(def=5[SPC-3])");
2117 MODULE_PARM_DESC(virtual_gb
, "virtual gigabyte size (def=0 -> use dev_size_mb)");
2118 MODULE_PARM_DESC(vpd_use_hostno
, "0 -> dev ids ignore hostno (def=1 -> unique dev ids)");
2119 MODULE_PARM_DESC(sector_size
, "hardware sector size in bytes (def=512)");
2122 static char sdebug_info
[256];
2124 static const char * scsi_debug_info(struct Scsi_Host
* shp
)
2126 sprintf(sdebug_info
, "scsi_debug, version %s [%s], "
2127 "dev_size_mb=%d, opts=0x%x", SCSI_DEBUG_VERSION
,
2128 scsi_debug_version_date
, scsi_debug_dev_size_mb
,
2133 /* scsi_debug_proc_info
2134 * Used if the driver currently has no own support for /proc/scsi
2136 static int scsi_debug_proc_info(struct Scsi_Host
*host
, char *buffer
, char **start
, off_t offset
,
2137 int length
, int inout
)
2139 int len
, pos
, begin
;
2142 orig_length
= length
;
2146 int minLen
= length
> 15 ? 15 : length
;
2148 if (!capable(CAP_SYS_ADMIN
) || !capable(CAP_SYS_RAWIO
))
2150 memcpy(arr
, buffer
, minLen
);
2152 if (1 != sscanf(arr
, "%d", &pos
))
2154 scsi_debug_opts
= pos
;
2155 if (scsi_debug_every_nth
!= 0)
2156 scsi_debug_cmnd_count
= 0;
2160 pos
= len
= sprintf(buffer
, "scsi_debug adapter driver, version "
2162 "num_tgts=%d, shared (ram) size=%d MB, opts=0x%x, "
2163 "every_nth=%d(curr:%d)\n"
2164 "delay=%d, max_luns=%d, scsi_level=%d\n"
2165 "sector_size=%d bytes, cylinders=%d, heads=%d, sectors=%d\n"
2166 "number of aborts=%d, device_reset=%d, bus_resets=%d, "
2168 SCSI_DEBUG_VERSION
, scsi_debug_version_date
, scsi_debug_num_tgts
,
2169 scsi_debug_dev_size_mb
, scsi_debug_opts
, scsi_debug_every_nth
,
2170 scsi_debug_cmnd_count
, scsi_debug_delay
,
2171 scsi_debug_max_luns
, scsi_debug_scsi_level
,
2172 scsi_debug_sector_size
, sdebug_cylinders_per
, sdebug_heads
,
2173 sdebug_sectors_per
, num_aborts
, num_dev_resets
, num_bus_resets
,
2179 *start
= buffer
+ (offset
- begin
); /* Start of wanted data */
2180 len
-= (offset
- begin
);
2186 static ssize_t
sdebug_delay_show(struct device_driver
* ddp
, char * buf
)
2188 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_delay
);
2191 static ssize_t
sdebug_delay_store(struct device_driver
* ddp
,
2192 const char * buf
, size_t count
)
2197 if (1 == sscanf(buf
, "%10s", work
)) {
2198 if ((1 == sscanf(work
, "%d", &delay
)) && (delay
>= 0)) {
2199 scsi_debug_delay
= delay
;
2205 DRIVER_ATTR(delay
, S_IRUGO
| S_IWUSR
, sdebug_delay_show
,
2206 sdebug_delay_store
);
2208 static ssize_t
sdebug_opts_show(struct device_driver
* ddp
, char * buf
)
2210 return scnprintf(buf
, PAGE_SIZE
, "0x%x\n", scsi_debug_opts
);
2213 static ssize_t
sdebug_opts_store(struct device_driver
* ddp
,
2214 const char * buf
, size_t count
)
2219 if (1 == sscanf(buf
, "%10s", work
)) {
2220 if (0 == strnicmp(work
,"0x", 2)) {
2221 if (1 == sscanf(&work
[2], "%x", &opts
))
2224 if (1 == sscanf(work
, "%d", &opts
))
2230 scsi_debug_opts
= opts
;
2231 scsi_debug_cmnd_count
= 0;
2234 DRIVER_ATTR(opts
, S_IRUGO
| S_IWUSR
, sdebug_opts_show
,
2237 static ssize_t
sdebug_ptype_show(struct device_driver
* ddp
, char * buf
)
2239 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_ptype
);
2241 static ssize_t
sdebug_ptype_store(struct device_driver
* ddp
,
2242 const char * buf
, size_t count
)
2246 if ((count
> 0) && (1 == sscanf(buf
, "%d", &n
)) && (n
>= 0)) {
2247 scsi_debug_ptype
= n
;
2252 DRIVER_ATTR(ptype
, S_IRUGO
| S_IWUSR
, sdebug_ptype_show
, sdebug_ptype_store
);
2254 static ssize_t
sdebug_dsense_show(struct device_driver
* ddp
, char * buf
)
2256 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_dsense
);
2258 static ssize_t
sdebug_dsense_store(struct device_driver
* ddp
,
2259 const char * buf
, size_t count
)
2263 if ((count
> 0) && (1 == sscanf(buf
, "%d", &n
)) && (n
>= 0)) {
2264 scsi_debug_dsense
= n
;
2269 DRIVER_ATTR(dsense
, S_IRUGO
| S_IWUSR
, sdebug_dsense_show
,
2270 sdebug_dsense_store
);
2272 static ssize_t
sdebug_fake_rw_show(struct device_driver
* ddp
, char * buf
)
2274 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_fake_rw
);
2276 static ssize_t
sdebug_fake_rw_store(struct device_driver
* ddp
,
2277 const char * buf
, size_t count
)
2281 if ((count
> 0) && (1 == sscanf(buf
, "%d", &n
)) && (n
>= 0)) {
2282 scsi_debug_fake_rw
= n
;
2287 DRIVER_ATTR(fake_rw
, S_IRUGO
| S_IWUSR
, sdebug_fake_rw_show
,
2288 sdebug_fake_rw_store
);
2290 static ssize_t
sdebug_no_lun_0_show(struct device_driver
* ddp
, char * buf
)
2292 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_no_lun_0
);
2294 static ssize_t
sdebug_no_lun_0_store(struct device_driver
* ddp
,
2295 const char * buf
, size_t count
)
2299 if ((count
> 0) && (1 == sscanf(buf
, "%d", &n
)) && (n
>= 0)) {
2300 scsi_debug_no_lun_0
= n
;
2305 DRIVER_ATTR(no_lun_0
, S_IRUGO
| S_IWUSR
, sdebug_no_lun_0_show
,
2306 sdebug_no_lun_0_store
);
2308 static ssize_t
sdebug_num_tgts_show(struct device_driver
* ddp
, char * buf
)
2310 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_num_tgts
);
2312 static ssize_t
sdebug_num_tgts_store(struct device_driver
* ddp
,
2313 const char * buf
, size_t count
)
2317 if ((count
> 0) && (1 == sscanf(buf
, "%d", &n
)) && (n
>= 0)) {
2318 scsi_debug_num_tgts
= n
;
2319 sdebug_max_tgts_luns();
2324 DRIVER_ATTR(num_tgts
, S_IRUGO
| S_IWUSR
, sdebug_num_tgts_show
,
2325 sdebug_num_tgts_store
);
2327 static ssize_t
sdebug_dev_size_mb_show(struct device_driver
* ddp
, char * buf
)
2329 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_dev_size_mb
);
2331 DRIVER_ATTR(dev_size_mb
, S_IRUGO
, sdebug_dev_size_mb_show
, NULL
);
2333 static ssize_t
sdebug_num_parts_show(struct device_driver
* ddp
, char * buf
)
2335 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_num_parts
);
2337 DRIVER_ATTR(num_parts
, S_IRUGO
, sdebug_num_parts_show
, NULL
);
2339 static ssize_t
sdebug_every_nth_show(struct device_driver
* ddp
, char * buf
)
2341 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_every_nth
);
2343 static ssize_t
sdebug_every_nth_store(struct device_driver
* ddp
,
2344 const char * buf
, size_t count
)
2348 if ((count
> 0) && (1 == sscanf(buf
, "%d", &nth
))) {
2349 scsi_debug_every_nth
= nth
;
2350 scsi_debug_cmnd_count
= 0;
2355 DRIVER_ATTR(every_nth
, S_IRUGO
| S_IWUSR
, sdebug_every_nth_show
,
2356 sdebug_every_nth_store
);
2358 static ssize_t
sdebug_max_luns_show(struct device_driver
* ddp
, char * buf
)
2360 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_max_luns
);
2362 static ssize_t
sdebug_max_luns_store(struct device_driver
* ddp
,
2363 const char * buf
, size_t count
)
2367 if ((count
> 0) && (1 == sscanf(buf
, "%d", &n
)) && (n
>= 0)) {
2368 scsi_debug_max_luns
= n
;
2369 sdebug_max_tgts_luns();
2374 DRIVER_ATTR(max_luns
, S_IRUGO
| S_IWUSR
, sdebug_max_luns_show
,
2375 sdebug_max_luns_store
);
2377 static ssize_t
sdebug_scsi_level_show(struct device_driver
* ddp
, char * buf
)
2379 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_scsi_level
);
2381 DRIVER_ATTR(scsi_level
, S_IRUGO
, sdebug_scsi_level_show
, NULL
);
2383 static ssize_t
sdebug_virtual_gb_show(struct device_driver
* ddp
, char * buf
)
2385 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_virtual_gb
);
2387 static ssize_t
sdebug_virtual_gb_store(struct device_driver
* ddp
,
2388 const char * buf
, size_t count
)
2392 if ((count
> 0) && (1 == sscanf(buf
, "%d", &n
)) && (n
>= 0)) {
2393 scsi_debug_virtual_gb
= n
;
2395 sdebug_capacity
= get_sdebug_capacity();
2401 DRIVER_ATTR(virtual_gb
, S_IRUGO
| S_IWUSR
, sdebug_virtual_gb_show
,
2402 sdebug_virtual_gb_store
);
2404 static ssize_t
sdebug_add_host_show(struct device_driver
* ddp
, char * buf
)
2406 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_add_host
);
2409 static ssize_t
sdebug_add_host_store(struct device_driver
* ddp
,
2410 const char * buf
, size_t count
)
2414 if (sscanf(buf
, "%d", &delta_hosts
) != 1)
2416 if (delta_hosts
> 0) {
2418 sdebug_add_adapter();
2419 } while (--delta_hosts
);
2420 } else if (delta_hosts
< 0) {
2422 sdebug_remove_adapter();
2423 } while (++delta_hosts
);
2427 DRIVER_ATTR(add_host
, S_IRUGO
| S_IWUSR
, sdebug_add_host_show
,
2428 sdebug_add_host_store
);
2430 static ssize_t
sdebug_vpd_use_hostno_show(struct device_driver
* ddp
,
2433 return scnprintf(buf
, PAGE_SIZE
, "%d\n", scsi_debug_vpd_use_hostno
);
2435 static ssize_t
sdebug_vpd_use_hostno_store(struct device_driver
* ddp
,
2436 const char * buf
, size_t count
)
2440 if ((count
> 0) && (1 == sscanf(buf
, "%d", &n
)) && (n
>= 0)) {
2441 scsi_debug_vpd_use_hostno
= n
;
2446 DRIVER_ATTR(vpd_use_hostno
, S_IRUGO
| S_IWUSR
, sdebug_vpd_use_hostno_show
,
2447 sdebug_vpd_use_hostno_store
);
2449 static ssize_t
sdebug_sector_size_show(struct device_driver
* ddp
, char * buf
)
2451 return scnprintf(buf
, PAGE_SIZE
, "%u\n", scsi_debug_sector_size
);
2453 DRIVER_ATTR(sector_size
, S_IRUGO
, sdebug_sector_size_show
, NULL
);
2455 /* Note: The following function creates attribute files in the
2456 /sys/bus/pseudo/drivers/scsi_debug directory. The advantage of these
2457 files (over those found in the /sys/module/scsi_debug/parameters
2458 directory) is that auxiliary actions can be triggered when an attribute
2459 is changed. For example see: sdebug_add_host_store() above.
2461 static int do_create_driverfs_files(void)
2465 ret
= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_add_host
);
2466 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_delay
);
2467 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_dev_size_mb
);
2468 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_dsense
);
2469 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_every_nth
);
2470 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_fake_rw
);
2471 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_max_luns
);
2472 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_no_lun_0
);
2473 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_num_parts
);
2474 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_num_tgts
);
2475 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_ptype
);
2476 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_opts
);
2477 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_scsi_level
);
2478 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_virtual_gb
);
2479 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_vpd_use_hostno
);
2480 ret
|= driver_create_file(&sdebug_driverfs_driver
, &driver_attr_sector_size
);
2484 static void do_remove_driverfs_files(void)
2486 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_sector_size
);
2487 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_vpd_use_hostno
);
2488 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_virtual_gb
);
2489 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_scsi_level
);
2490 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_opts
);
2491 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_ptype
);
2492 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_num_tgts
);
2493 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_num_parts
);
2494 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_no_lun_0
);
2495 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_max_luns
);
2496 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_fake_rw
);
2497 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_every_nth
);
2498 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_dsense
);
2499 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_dev_size_mb
);
2500 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_delay
);
2501 driver_remove_file(&sdebug_driverfs_driver
, &driver_attr_add_host
);
2504 static void pseudo_0_release(struct device
*dev
)
2506 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
2507 printk(KERN_INFO
"scsi_debug: pseudo_0_release() called\n");
2510 static struct device pseudo_primary
= {
2511 .bus_id
= "pseudo_0",
2512 .release
= pseudo_0_release
,
2515 static int __init
scsi_debug_init(void)
2522 switch (scsi_debug_sector_size
) {
2529 printk(KERN_ERR
"scsi_debug_init: invalid sector_size %u\n",
2530 scsi_debug_sector_size
);
2534 if (scsi_debug_dev_size_mb
< 1)
2535 scsi_debug_dev_size_mb
= 1; /* force minimum 1 MB ramdisk */
2536 sz
= (unsigned long)scsi_debug_dev_size_mb
* 1048576;
2537 sdebug_store_sectors
= sz
/ scsi_debug_sector_size
;
2538 sdebug_capacity
= get_sdebug_capacity();
2540 /* play around with geometry, don't waste too much on track 0 */
2542 sdebug_sectors_per
= 32;
2543 if (scsi_debug_dev_size_mb
>= 16)
2545 else if (scsi_debug_dev_size_mb
>= 256)
2547 sdebug_cylinders_per
= (unsigned long)sdebug_capacity
/
2548 (sdebug_sectors_per
* sdebug_heads
);
2549 if (sdebug_cylinders_per
>= 1024) {
2550 /* other LLDs do this; implies >= 1GB ram disk ... */
2552 sdebug_sectors_per
= 63;
2553 sdebug_cylinders_per
= (unsigned long)sdebug_capacity
/
2554 (sdebug_sectors_per
* sdebug_heads
);
2557 fake_storep
= vmalloc(sz
);
2558 if (NULL
== fake_storep
) {
2559 printk(KERN_ERR
"scsi_debug_init: out of memory, 1\n");
2562 memset(fake_storep
, 0, sz
);
2563 if (scsi_debug_num_parts
> 0)
2564 sdebug_build_parts(fake_storep
, sz
);
2566 ret
= device_register(&pseudo_primary
);
2568 printk(KERN_WARNING
"scsi_debug: device_register error: %d\n",
2572 ret
= bus_register(&pseudo_lld_bus
);
2574 printk(KERN_WARNING
"scsi_debug: bus_register error: %d\n",
2578 ret
= driver_register(&sdebug_driverfs_driver
);
2580 printk(KERN_WARNING
"scsi_debug: driver_register error: %d\n",
2584 ret
= do_create_driverfs_files();
2586 printk(KERN_WARNING
"scsi_debug: driver_create_file error: %d\n",
2593 host_to_add
= scsi_debug_add_host
;
2594 scsi_debug_add_host
= 0;
2596 for (k
= 0; k
< host_to_add
; k
++) {
2597 if (sdebug_add_adapter()) {
2598 printk(KERN_ERR
"scsi_debug_init: "
2599 "sdebug_add_adapter failed k=%d\n", k
);
2604 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
) {
2605 printk(KERN_INFO
"scsi_debug_init: built %d host(s)\n",
2606 scsi_debug_add_host
);
2611 do_remove_driverfs_files();
2612 driver_unregister(&sdebug_driverfs_driver
);
2614 bus_unregister(&pseudo_lld_bus
);
2616 device_unregister(&pseudo_primary
);
2623 static void __exit
scsi_debug_exit(void)
2625 int k
= scsi_debug_add_host
;
2629 sdebug_remove_adapter();
2630 do_remove_driverfs_files();
2631 driver_unregister(&sdebug_driverfs_driver
);
2632 bus_unregister(&pseudo_lld_bus
);
2633 device_unregister(&pseudo_primary
);
2638 device_initcall(scsi_debug_init
);
2639 module_exit(scsi_debug_exit
);
2641 static void sdebug_release_adapter(struct device
* dev
)
2643 struct sdebug_host_info
*sdbg_host
;
2645 sdbg_host
= to_sdebug_host(dev
);
2649 static int sdebug_add_adapter(void)
2651 int k
, devs_per_host
;
2653 struct sdebug_host_info
*sdbg_host
;
2654 struct sdebug_dev_info
*sdbg_devinfo
, *tmp
;
2656 sdbg_host
= kzalloc(sizeof(*sdbg_host
),GFP_KERNEL
);
2657 if (NULL
== sdbg_host
) {
2658 printk(KERN_ERR
"%s: out of memory at line %d\n",
2659 __func__
, __LINE__
);
2663 INIT_LIST_HEAD(&sdbg_host
->dev_info_list
);
2665 devs_per_host
= scsi_debug_num_tgts
* scsi_debug_max_luns
;
2666 for (k
= 0; k
< devs_per_host
; k
++) {
2667 sdbg_devinfo
= sdebug_device_create(sdbg_host
, GFP_KERNEL
);
2668 if (!sdbg_devinfo
) {
2669 printk(KERN_ERR
"%s: out of memory at line %d\n",
2670 __func__
, __LINE__
);
2676 spin_lock(&sdebug_host_list_lock
);
2677 list_add_tail(&sdbg_host
->host_list
, &sdebug_host_list
);
2678 spin_unlock(&sdebug_host_list_lock
);
2680 sdbg_host
->dev
.bus
= &pseudo_lld_bus
;
2681 sdbg_host
->dev
.parent
= &pseudo_primary
;
2682 sdbg_host
->dev
.release
= &sdebug_release_adapter
;
2683 sprintf(sdbg_host
->dev
.bus_id
, "adapter%d", scsi_debug_add_host
);
2685 error
= device_register(&sdbg_host
->dev
);
2690 ++scsi_debug_add_host
;
2694 list_for_each_entry_safe(sdbg_devinfo
, tmp
, &sdbg_host
->dev_info_list
,
2696 list_del(&sdbg_devinfo
->dev_list
);
2697 kfree(sdbg_devinfo
);
2704 static void sdebug_remove_adapter(void)
2706 struct sdebug_host_info
* sdbg_host
= NULL
;
2708 spin_lock(&sdebug_host_list_lock
);
2709 if (!list_empty(&sdebug_host_list
)) {
2710 sdbg_host
= list_entry(sdebug_host_list
.prev
,
2711 struct sdebug_host_info
, host_list
);
2712 list_del(&sdbg_host
->host_list
);
2714 spin_unlock(&sdebug_host_list_lock
);
2719 device_unregister(&sdbg_host
->dev
);
2720 --scsi_debug_add_host
;
2724 int scsi_debug_queuecommand(struct scsi_cmnd
*SCpnt
, done_funct_t done
)
2726 unsigned char *cmd
= (unsigned char *) SCpnt
->cmnd
;
2729 unsigned long long lba
;
2731 int target
= SCpnt
->device
->id
;
2732 struct sdebug_dev_info
*devip
= NULL
;
2733 int inj_recovered
= 0;
2734 int inj_transport
= 0;
2735 int delay_override
= 0;
2737 scsi_set_resid(SCpnt
, 0);
2738 if ((SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
) && cmd
) {
2739 printk(KERN_INFO
"scsi_debug: cmd ");
2740 for (k
= 0, len
= SCpnt
->cmd_len
; k
< len
; ++k
)
2741 printk("%02x ", (int)cmd
[k
]);
2745 if (target
== SCpnt
->device
->host
->hostt
->this_id
) {
2746 printk(KERN_INFO
"scsi_debug: initiator's id used as "
2748 return schedule_resp(SCpnt
, NULL
, done
,
2749 DID_NO_CONNECT
<< 16, 0);
2752 if ((SCpnt
->device
->lun
>= scsi_debug_max_luns
) &&
2753 (SCpnt
->device
->lun
!= SAM2_WLUN_REPORT_LUNS
))
2754 return schedule_resp(SCpnt
, NULL
, done
,
2755 DID_NO_CONNECT
<< 16, 0);
2756 devip
= devInfoReg(SCpnt
->device
);
2758 return schedule_resp(SCpnt
, NULL
, done
,
2759 DID_NO_CONNECT
<< 16, 0);
2761 if ((scsi_debug_every_nth
!= 0) &&
2762 (++scsi_debug_cmnd_count
>= abs(scsi_debug_every_nth
))) {
2763 scsi_debug_cmnd_count
= 0;
2764 if (scsi_debug_every_nth
< -1)
2765 scsi_debug_every_nth
= -1;
2766 if (SCSI_DEBUG_OPT_TIMEOUT
& scsi_debug_opts
)
2767 return 0; /* ignore command causing timeout */
2768 else if (SCSI_DEBUG_OPT_RECOVERED_ERR
& scsi_debug_opts
)
2769 inj_recovered
= 1; /* to reads and writes below */
2770 else if (SCSI_DEBUG_OPT_TRANSPORT_ERR
& scsi_debug_opts
)
2771 inj_transport
= 1; /* to reads and writes below */
2778 case TEST_UNIT_READY
:
2780 break; /* only allowable wlun commands */
2782 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
2783 printk(KERN_INFO
"scsi_debug: Opcode: 0x%x "
2784 "not supported for wlun\n", *cmd
);
2785 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
2787 errsts
= check_condition_result
;
2788 return schedule_resp(SCpnt
, devip
, done
, errsts
,
2794 case INQUIRY
: /* mandatory, ignore unit attention */
2796 errsts
= resp_inquiry(SCpnt
, target
, devip
);
2798 case REQUEST_SENSE
: /* mandatory, ignore unit attention */
2800 errsts
= resp_requests(SCpnt
, devip
);
2802 case REZERO_UNIT
: /* actually this is REWIND for SSC */
2804 errsts
= resp_start_stop(SCpnt
, devip
);
2806 case ALLOW_MEDIUM_REMOVAL
:
2807 errsts
= check_readiness(SCpnt
, 1, devip
);
2810 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
2811 printk(KERN_INFO
"scsi_debug: Medium removal %s\n",
2812 cmd
[4] ? "inhibited" : "enabled");
2814 case SEND_DIAGNOSTIC
: /* mandatory */
2815 errsts
= check_readiness(SCpnt
, 1, devip
);
2817 case TEST_UNIT_READY
: /* mandatory */
2819 errsts
= check_readiness(SCpnt
, 0, devip
);
2822 errsts
= check_readiness(SCpnt
, 1, devip
);
2825 errsts
= check_readiness(SCpnt
, 1, devip
);
2828 errsts
= check_readiness(SCpnt
, 1, devip
);
2831 errsts
= check_readiness(SCpnt
, 1, devip
);
2834 errsts
= resp_readcap(SCpnt
, devip
);
2836 case SERVICE_ACTION_IN
:
2837 if (SAI_READ_CAPACITY_16
!= cmd
[1]) {
2838 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
2840 errsts
= check_condition_result
;
2843 errsts
= resp_readcap16(SCpnt
, devip
);
2845 case MAINTENANCE_IN
:
2846 if (MI_REPORT_TARGET_PGS
!= cmd
[1]) {
2847 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
2849 errsts
= check_condition_result
;
2852 errsts
= resp_report_tgtpgs(SCpnt
, devip
);
2858 errsts
= check_readiness(SCpnt
, 0, devip
);
2861 if (scsi_debug_fake_rw
)
2863 get_data_transfer_info(cmd
, &lba
, &num
);
2864 errsts
= resp_read(SCpnt
, lba
, num
, devip
);
2865 if (inj_recovered
&& (0 == errsts
)) {
2866 mk_sense_buffer(devip
, RECOVERED_ERROR
,
2867 THRESHOLD_EXCEEDED
, 0);
2868 errsts
= check_condition_result
;
2869 } else if (inj_transport
&& (0 == errsts
)) {
2870 mk_sense_buffer(devip
, ABORTED_COMMAND
,
2871 TRANSPORT_PROBLEM
, ACK_NAK_TO
);
2872 errsts
= check_condition_result
;
2875 case REPORT_LUNS
: /* mandatory, ignore unit attention */
2877 errsts
= resp_report_luns(SCpnt
, devip
);
2879 case VERIFY
: /* 10 byte SBC-2 command */
2880 errsts
= check_readiness(SCpnt
, 0, devip
);
2886 errsts
= check_readiness(SCpnt
, 0, devip
);
2889 if (scsi_debug_fake_rw
)
2891 get_data_transfer_info(cmd
, &lba
, &num
);
2892 errsts
= resp_write(SCpnt
, lba
, num
, devip
);
2893 if (inj_recovered
&& (0 == errsts
)) {
2894 mk_sense_buffer(devip
, RECOVERED_ERROR
,
2895 THRESHOLD_EXCEEDED
, 0);
2896 errsts
= check_condition_result
;
2901 errsts
= resp_mode_sense(SCpnt
, target
, devip
);
2904 errsts
= resp_mode_select(SCpnt
, 1, devip
);
2906 case MODE_SELECT_10
:
2907 errsts
= resp_mode_select(SCpnt
, 0, devip
);
2910 errsts
= resp_log_sense(SCpnt
, devip
);
2912 case SYNCHRONIZE_CACHE
:
2914 errsts
= check_readiness(SCpnt
, 0, devip
);
2917 errsts
= check_readiness(SCpnt
, 1, devip
);
2919 case XDWRITEREAD_10
:
2920 if (!scsi_bidi_cmnd(SCpnt
)) {
2921 mk_sense_buffer(devip
, ILLEGAL_REQUEST
,
2922 INVALID_FIELD_IN_CDB
, 0);
2923 errsts
= check_condition_result
;
2927 errsts
= check_readiness(SCpnt
, 0, devip
);
2930 if (scsi_debug_fake_rw
)
2932 get_data_transfer_info(cmd
, &lba
, &num
);
2933 errsts
= resp_read(SCpnt
, lba
, num
, devip
);
2936 errsts
= resp_write(SCpnt
, lba
, num
, devip
);
2939 errsts
= resp_xdwriteread(SCpnt
, lba
, num
, devip
);
2942 if (SCSI_DEBUG_OPT_NOISE
& scsi_debug_opts
)
2943 printk(KERN_INFO
"scsi_debug: Opcode: 0x%x not "
2944 "supported\n", *cmd
);
2945 errsts
= check_readiness(SCpnt
, 1, devip
);
2947 break; /* Unit attention takes precedence */
2948 mk_sense_buffer(devip
, ILLEGAL_REQUEST
, INVALID_OPCODE
, 0);
2949 errsts
= check_condition_result
;
2952 return schedule_resp(SCpnt
, devip
, done
, errsts
,
2953 (delay_override
? 0 : scsi_debug_delay
));
2956 static struct scsi_host_template sdebug_driver_template
= {
2957 .proc_info
= scsi_debug_proc_info
,
2958 .proc_name
= sdebug_proc_name
,
2959 .name
= "SCSI DEBUG",
2960 .info
= scsi_debug_info
,
2961 .slave_alloc
= scsi_debug_slave_alloc
,
2962 .slave_configure
= scsi_debug_slave_configure
,
2963 .slave_destroy
= scsi_debug_slave_destroy
,
2964 .ioctl
= scsi_debug_ioctl
,
2965 .queuecommand
= scsi_debug_queuecommand
,
2966 .eh_abort_handler
= scsi_debug_abort
,
2967 .eh_bus_reset_handler
= scsi_debug_bus_reset
,
2968 .eh_device_reset_handler
= scsi_debug_device_reset
,
2969 .eh_host_reset_handler
= scsi_debug_host_reset
,
2970 .bios_param
= scsi_debug_biosparam
,
2971 .can_queue
= SCSI_DEBUG_CANQUEUE
,
2973 .sg_tablesize
= 256,
2975 .max_sectors
= 0xffff,
2976 .use_clustering
= DISABLE_CLUSTERING
,
2977 .module
= THIS_MODULE
,
2980 static int sdebug_driver_probe(struct device
* dev
)
2983 struct sdebug_host_info
*sdbg_host
;
2984 struct Scsi_Host
*hpnt
;
2986 sdbg_host
= to_sdebug_host(dev
);
2988 hpnt
= scsi_host_alloc(&sdebug_driver_template
, sizeof(sdbg_host
));
2990 printk(KERN_ERR
"%s: scsi_register failed\n", __func__
);
2995 sdbg_host
->shost
= hpnt
;
2996 *((struct sdebug_host_info
**)hpnt
->hostdata
) = sdbg_host
;
2997 if ((hpnt
->this_id
>= 0) && (scsi_debug_num_tgts
> hpnt
->this_id
))
2998 hpnt
->max_id
= scsi_debug_num_tgts
+ 1;
3000 hpnt
->max_id
= scsi_debug_num_tgts
;
3001 hpnt
->max_lun
= SAM2_WLUN_REPORT_LUNS
; /* = scsi_debug_max_luns; */
3003 error
= scsi_add_host(hpnt
, &sdbg_host
->dev
);
3005 printk(KERN_ERR
"%s: scsi_add_host failed\n", __func__
);
3007 scsi_host_put(hpnt
);
3009 scsi_scan_host(hpnt
);
3015 static int sdebug_driver_remove(struct device
* dev
)
3017 struct sdebug_host_info
*sdbg_host
;
3018 struct sdebug_dev_info
*sdbg_devinfo
, *tmp
;
3020 sdbg_host
= to_sdebug_host(dev
);
3023 printk(KERN_ERR
"%s: Unable to locate host info\n",
3028 scsi_remove_host(sdbg_host
->shost
);
3030 list_for_each_entry_safe(sdbg_devinfo
, tmp
, &sdbg_host
->dev_info_list
,
3032 list_del(&sdbg_devinfo
->dev_list
);
3033 kfree(sdbg_devinfo
);
3036 scsi_host_put(sdbg_host
->shost
);
3040 static int pseudo_lld_bus_match(struct device
*dev
,
3041 struct device_driver
*dev_driver
)
3046 static struct bus_type pseudo_lld_bus
= {
3048 .match
= pseudo_lld_bus_match
,
3049 .probe
= sdebug_driver_probe
,
3050 .remove
= sdebug_driver_remove
,