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,